test 

Volume in drive E is 001206_1632 
Volume Serial Number is 33CE-90D1 



Directory of E:\ 

12/06/00 04:32p <DIR> 
12/06/00 04:32p <DIR> 
12/06/00 04:33p <DIR> 

3 File{s) 

Directory of E:\e-speak-src_991217 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
3 File(s) 



e-speak-src_991217 

0 bytes 



platform 
0 bytes 



:*=^ Directory of E:\e-speak-src_991217\platform 



tl2/06/00 04:33p <DIR> 

fl2/06/00 04:33p <DIR> 

fl2/06/00 04:33p <DIR> 

] 3 File(s) 



ES 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES 



;i2/06/00' 


04 


: 33p 


<DIR> 






^12/06/00 


04 


:33p 


<DIR> 






S12/06/00 


04 


:33p 


<DIR> 




bin 


512/06/00 


04 


:33p 


<DIR> 




conf ig 


n2/15/99 


04 


: OOp 




54,294 


configure 


12/15/99 


04 


: OOp 




10,314 


configure . in 


12/07/99 


04 


:25p 




53 


configure.nt 


12/06/00 


04 


:33p 


<DIR> 




contrib 


12/07/99 


04 


:25p 




15, 413 


COPYING 


12/07/99 


04 


:25p 




23,237 


COPYING. LIB 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/06/00 


04 


: 33p 


<DIR> 




extern 


12/07/99 


04 


:25p 




20,163 


HowTo . html 


12/15/99 


04 


: OOp 




4,224 


include. mk. in 


12/15/99 


04 


: OOp 




13,149 


Makefile . in 


12/07/99 


04 


:25p 




1,509 


make. rules 


12/06/00 


04 


: 33p 


<DIR> 




samples 


12/06/00 


04 


: 33p 


<DIR> 




src 


12/06/00 


04 


: 33p 


<DIR> 




tutorial 






19 


File (S) 


142,35 


6 bytes 
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test 

Directory of E:\e-speak-src_991217\platform\ES\bin 



Iz / Uo/ UU 


U4 


. O O 

: i3p 


<DIR> 


Iz/UD/UU 


04 


: 33p 


<DIR> 


iZ/Ub/Uu 




: J op 


<DIR> 


19/07 / QQ 


n A 
U 4± 


• ^ -*p 




12/07/99 


04 


:25p 




12/07/99 


04 


:25p 




12/07/99 


04 


:25p 




12/07/99 


04 


:25p 




12/15/99 


04 


: OOp 




12/07/99 


04 


: 25p 








10 


File (s) 



CVS 

2,040 envmake 
2,007 envmake.bat 
2,673 envset 

27 eshome.bat 
7,292 genenv.pl 
17,909 install.pl 
35,269 run.pl 
67,217 bytes 

Directory of E:\e-speak-src_991217\platform\ES\bin\CVS 

12/06/00 04:33p <DIR> 

il2/06/00 04:33p <DIR> 

112/16/99 06:18p 321 Entries 

112/16/99 06:17p 31 Repository 

='12/16/99 06:17p 46 Root 

J12/16/99 06:17p 846 Template 

[ 6 File(s) 1,244 bytes 

' Directory of E:\e-speak-src_991217\platform\ES\config 



CO 

22 col 
22 co2 
22 codef 
133 core.ini 
CVS 

1,039 default.ini 

149 espeak_ldap . prop 
management 
25 multiplecf . cf g 
510 repository.ini 
17 sample. cfg 
1, 939 bytes 

Directory of E:\e-speak-src_991217\platform\ES\config\co 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:25p 22 col 

12/07/99 04:25p 22 colO 
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!f;i2/06/00 


04 


:33p 


<DIR> 


^ifl2/06/00 


04 


: 33p 


<DIR> 


^12/06/00 


04 


: 33p 


<DIR> 


:ifl2/07/99 


04 


: 25p 




'S12/07/99 


04 


:25p 




^=^12/07/99 


04 


:25p 




12/07/99 


04 


:25p 




12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:25p 




12/07/99 


04 


:25p 




12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:25p 




12/07/99 


04 


:25p 




12/07/99 


04 


:25p 








14 


File (s) 



test 





1 9 / Cil / QQ 


n /f . O 

u 4 : z op 


22 


col . stress 




1 9 707 /QQ 


U4 : Z Op 


22 


co2 




19 / m / QQ 


U4 : zop 


22 


co2 . stress 




19 / n'7 / QQ 


U4 : Zop 


22 


co3 




19/07 / QQ 

iz/ u / / y y 


U4 : zop 


22 


co3 . stress 




1 9 / n7 / QQ 

xz / u / / y y 


n /i . o c-^ 
U4 : Z op 


22 


co4 




1 9 /n7 / QQ 

xz / u / / y y 


U4 : Zop 


30 


CO . SVEN . OMNIBOOKl 




1 9 / n7 /QQ 

xz / u / / y y 


U4 : Zop 


22 


co4 . stress 




1 9 / n7 /QQ 

XZ/ u / / y y 


A / . O C ^ 

U4 : 2op 


22 


co5 




xz/u / /yy 


Ay! _ O c 

04 : 2op 


30 


GO. SVEN . OMNIBOOK 




iZ/U // 99 


A y1 An 

04 : 25p 


22 


co5 . stress 




XZ/U 1 1 


d A . O C 

04 : zop 


22 


co6 




xz/u / /yy 


d A - O ET 

04 : Zop 


24 


CO. PHIL. OMNI 3 




iz/ u / / y y 


d A - O IT 

04 : 2op 


22 


co7 




XZ/U / / y y 


d A . O C « 

04 : zop 


22 


co8 




19 / Oil / no 

xz/u 1/33 


A /I _ O C 

04 : zop 


22 


co9 




19 / n7 / an 

XZ/U //yy 


d A - O IT 

04 : 25p 


24 


CO. PHIL. OMNI 4 




IZ/ U7/99 


04 : 25p 


32 


co.CHIA.CHOWCHOWl 




T 9 /ri'7 / nn 
XZ/U 1/33 


A /I - O CT 

04 : 2op 


24 


co.PHIL.IUl 




XZ/U / / y y 


A >1 A I~ 

04 : 25p 


24 


CO.PHIL.IU24 


?! 


lZ/07/99 


04 : 25p 


33 


co.SVEN.KAYAKl 


: 


12/ Ql / 33 


04 : 25p 


22 


CO . CHIA. localhost 




lZ/07/99 


04 : 25p 


22 


CO . MYC03 




LZ/ \J 1/33 


A ^ A I~ 

04 : 25p 


24 


CO.PHIL.0MNI2 




12/07/99 


04 : 25p 


32 


co.CHIA.CHOWCHOW 




io / nn / nn 

1Z/U7/ 99 


A yt A r* 

04 : 25p 


24 


co.PHIL.IU23 




XZ/U / / y y 


A yi _ O IT 

04 : 2op 


33 


CO . SVEN . KAYAK 




12/07/99 


04 : 25p 


22 


CO.MYC02 




io / r\'~t / OA 

lZ/07/99 


04 : 25p 


24 


CO. PHIL. OMNI 




IO / dn / d d 
XZ/U 1/33 


04 : 25p 


24 


CO.PHIL.IU22 




1 9 /n7 / QQ 

XZ/U / /yy 


U4 : zop 


22 


co.MYCOl 




12/07 /99 




■3 n 
oU 


CO . CHIA . OMNIBOOKl 




12/07/99 


04:25p 


24 


CO.PHIL.IU2 




12/07/99 


04:25p 


22 


CO . MYCO 




12/07/99 


04:25p 


30 


CO. CHIA. OMNI BOOK 




12/06/00 


04:33p <DIR> 




CVS 






40 File(s) 


906 


bytes 



Directory of E:\e-speak-src_991217\platform\ES\config\co\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 

6 File(s) 



<DIR> 
<DIR> 



1,736 Entries 
37 Repository 
4 6 Root 
846 Template 
2,665 bytes 



Page 3 



test 

Directory of E:\e-speak-src_991217\platforin\ES\config\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 420 Entries 

12/16/99 06:18p 32 Entries. Log 

12/16/99 06:18p 34 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,378 bytes 

Directory of E: \e-speak-src_991217\platform\ES\conf ig\management 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 22 co2.dat 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> html 

12/07/99 04:25p 980 management.ini 

6 File(s) 1,002 bytes 

Directory of E : \e-speak-src_991217\platf orra\ES\conf ig\management\CVS 



ir: 12/06/00 


04 : 


33p 


<DIR> 






12/06/00 


04 : 


33p 


<DIR> 






12/16/99 


06: 


18p 




98 


Entries 


;r;i2/i6/99 


06: 


18p 




14 


Entries . Log 


12/16/99 


06: 


18p 




45 


Repository 


:i 12/16/99 


06: 


18p 




46 


Root 


;S 12/16/99 


06: 


18p 




846 


Template 



; 7 File{s) 1,049 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\conf ig\management\html 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> images 

12/07/99 04:25p 687 main.html 

12/07/99 04:25p 882 servlet . properties 

6 File(s) 1,569 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\conf ig\management\html 
\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 104 Entries 
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test 

12/16/99 06:18p 16 Entries. Log 

12/16/99 06:18p 50 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,062 bytes 

Directory of E: \e-speak-src_991217\platform\ES\conf ig\management\html 
\images 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 6,840 Closed.gif 
12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 6,910 Error.gif 

12/07/99 04:25p 6,852 Initializing.gif 

12/07/99 04:25p 5,058 logo.gif 

12/07/99 04:25p 6,897 Ready.gif 

J 12/07/99 04:25p 6,880 Running.gif 

;={ 9 File(s) 39,437 bytes 

;^ Directory of E:\e-speak-src_991217\platform\ES\config\management\html 
Ij; \images\CVS 

;::12/06/00 04:33p <DIR> 
^"==42/06/00 04:33p <DIR> 

r. 12/16/99 06:18p 288 Entries 

:^;;i2/16/99 06:18p 57 Repository 

;;-;12/16/99 06:18p 46 Root 

:;:12/16/99 06:18p 846 Template 

6 File(s) 1,237 bytes 

Directory of E:\e-speak-src_991217\platform\ES\contrib 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


browser 


12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


gsysmon 


12/15/99 


04 


: OOp 




245 Makefil 


12/06/00 


04 


: 33p 


<DIR> 


sysmon 


12/06/00 


04 


: 33p 


<DIR> 


vf s 






8 


File (s) 


245 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\browser 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 3,280 Browser. java 
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test 


<DIR> 


core 


<DIR> 


CVS 




991 Makefile 


<DIR> 


tree 


<DIR> 


ui 


<DIR> 


util 




4,271 bytes 



12/06/00 04:33p 
12/06/00 04:33p 
12/15/99 04:00p 
12/06/00 04:33p 
12/06/00 04:33p 
12/06/00 04:33p 

9 File(s) 

Directory of E: \e-speak-src_991217\platf orm\ES\contrib\browser\core 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:40p 12,861 CoreBrowser . j ava 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 390 Makefile 

5 File(s) 13,251 bytes 

I Directory of E:\e-speak-src_991217\platform\ES\contrib\browser\core\C 

^VS 

:12/06/00 04:33p <DIR> 
^12/06/00 04:33p <DIR> 

^12/16/99 06:18p 101 Entries 

;i2/16/99 06:18p 48 Repository 

'12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

= 6 File(s) 1,041 bytes 

; Directory of E:\e-speak-src_991217\platforin\ES\contrib\browser\CVS 



;S12/06/00 


04:33p 


<DIR> 




^=^12/06/00 


04:33p 


<DIR> 




12/16/99 


06: 18p 




97 


12/16/99 


06: 18p 




54 


12/16/99 


06:18p 




43 


12/16/99 


06:18p 




46 


12/16/99 


06: 18p 




846 



7 File(s) 1, 086 bytes 

Directory of E:\e-speak-src_991217\platform\ES\contrib\browser\tree 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:25p 246 a.gif 

12/07/99 04:25p 247 alert.red.gif 

12/07/99 04:25p 242 alert.black.gif 

12/07/99 04:25p 2,326 apache_pb.gif 

12/07/99 04:25p 1,573 AttributePropertyNode. java 
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test 



12/07/99 


04 : 25p 


2,096 


12/07/99 


04:25p 


216 


12/07/99 


04 :25p 


205 


12/07/99 


04 :25p 


233 


12/07/99 


04 :25p 


2,558 


12/07/99 


04:25p 


246 


12/07/99 


04:25p 


246 


12/07/99 


04:25p 


148 


12/07/99 


04:25p 


308 


12/07/99 


04:25p 


251 


12/07/99 


04 :25p 


268 


12/07/99 


04:25p 


247 


12/07/99 


04:25p 


235 


12/07/99 


04 :25p 


242 


12/07/99 


04:25p 


1,038 


12/07/99 


04:25p 


246 


12/07/99 


04:25p 


251 


Ol2/07/99 


04:25p 


214 


:Sl2/07/99 


04:25p 


1, 933 


'■^^12/06/00 


04:33p 


<DIR> 


i^h2/07/99 


04:25p 


225 


^12/07/99 


04:25p 


163 


:-12/07/99 


04:25p 


238 


r;l2/07/99 


04:25p 


1, 621 


^^12/07/99 


04:25p 


1, 619 


f 12/07/99 


04:25p 


1,729 


i!:i2/07/99 


04:25p 


1,436 


Jfl2/07/99 


04:25p 


236 


:il2/07/99 


04:25p 


225 


:ijl2/07/99 


04 :25p 


243 


^;!;l2/07/99 


04:25p 


242 


^'=^12/07/99 


04:25p 


219 


12/07/99 


04:25p 


221 


12/07/99 


04:25p 


249 


12/07/99 


04:25p 


220 


12/07/99 


04:25p 


223 


12/07/99 


04:25p 


217 


12/07/99 


04:25p 


11, 977 


12/07/99 


04:25p 


274 


12/07/99 


04:25p 


309 


12/07/99 


04:25p 


286 


12/07/99 


04:25p 


1, 467 


12/07/99 


04 : 25p 


268 


12/07/99 


04:25p 


276 


12/07/99 


04:25p 


172 


12/07/99 


04:25p 


249 


12/15/99 


04:00p 


969 


12/07/99 


04:25p 


243 



AttributeNode . j ava 
back, gif 
ball. red. gif 
ball, gray. gif 
BaseNode, java 
binary. gif 
binhex. gif 
blank. gif 
bomb. gif 
boxl . gif 
box2 . gif 
broken. gif 
burst . gif 
c. gif 

compressed. gif 
comp. gray . gif 
comp. blue. gif 
continued. gif 
CoreManagedNode . j ava 
CVS 

dir. gif 
down. gif 
dvi . gif 

ESContractNode . j ava 
ESNameFrameNode. java 
EsrlNode. java 
ESVocabularyNode . j ava 
f .gif 

folder . gif 
folder . sec , gif 
folder . open. gif 
forward. gif 
generic.gif 
generic. sec. gif 
generic. red. gif 
hand.up.gif 
hand. right-gif 
icon . sheet . gif 
imagel . gif 
image2.gif 
image3 . gif 
InboxNode . j ava 
index. gif 
layout . gif 
left . gif 
link. gif 
Makefile 
movie . gif 



Page 7 



test 



12/07/99 


04 : 25p 


237 


p.gif 


12/07/99 


04 : 25p 


251 


patch. gif 


12/07/99 


04 : 25p 


249 


pdf . gif 


12/07/99 


04 : 25p 


188 


pieO . gif 


12/07/99 


04 : 25p 


198 


piel . gif 


12/07/99 


04 :25p 


198 


pie2 . gif 


12/07/99 


04 :25p 


191 


pie3,gif 


12/07/99 


04 : 25p 


193 


pie4 • gif 


12/07/99 


04:25p 


189 


pie5 . gif 


12/07/99 


04 :25p 


186 


pie6.gif 


12/07/99 


04 : 25p 


185 


pie7 . gif 


12/07/99 


04 : 25p 


173 


pie8 . gif 


12/07/99 


04 :25p 


254 


portal . gif 


12/07/99 


04 :25p 


1,458 


Protect ionDomainNode , java 


12/07/99 


04:25p 


244 


ps . gif 


12/07/99 


04:25p 


267 


quill . gif 


_ 12/07/99 


04:25p 


1,438 


ResourceDescriptionNode .java 


O 12/07/99 


04 :25p 


172 


right . gif 


:fil2/07/99 


04:25p 


1,400 


RSDMapNode. java 


^"^12/07/99 


04:25p 


1,768 


RsdNode . java 


1^^12/07/99 


04 :25p 


258 


screwl . gif 


^^^12/07/99 


04:25p 


263 


screw2 , gif 


^12/07/99 


04:25p 


242 


script . gif 


1^12/07/99 


04:25p 


248 


soundl , gif 


^'^2/07/99 


04:25p 


221 


sound2 . gif 


:\, 12/07/99 


04:25p 


285 


spherel . gif 


:':i2/07/99 


04:25p 


264 


sphere2 . gif 


i{l2/07/99 


04:25p 


219 


tar . gif 


12/07/99 


04 :25p 


251 


tex.gif 


^J12/07/99 


04 :25p 


229 


text . gif 


1^:12/07/99 


04 :25p 


242 


transfer. gif 


^"''12/07/99 


04 :25p 


2,334 


TreeBrowser . j ava 


12/07/99 


04:25p 


2,435 


TreeCellRenderer , j ava 


12/07/99 


04:25p 


3,427 


TreeNodeFactory. java 


12/07/99 


04:25p 


8,315 


TreeResourceVisitor . java 


12/07/99 


04 :25p 


245 


unknown. gif 


12/07/99 


04 : 25p 


164 


up , gif 


12/07/99 


04:25p 


236 


uu . gif 


12/07/99 


04:25p 


236 


uuencoded. gif 


12/07/99 


04:25p 


228 


worldl . gif 


12/07/99 


04:25p 


261 


world2 . gif 




96 File(s) 


71, 673 


i bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\browser\tree\C 
VS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
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12/16/99 
12/16/99 
12/16/99 
12/16/99 



06:18p 
06:18p 
06: 18p 
06:18p 
6 



test 
4, 506 
48 
46 
846 



File(s; 



Entries 

Repository 

Root 

Template 



5,446 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\browser\ui 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
?12/06/00 
^12/07/99 
?12/07/99 
^12/07/99 
fl2/07/99 
^12/15/99 
'12/07/99 
^12/07/99 
.12/07/99 
:i2/07/99 
:i2/07/99 
a2/07/99 



04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:00p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

21 File(s) 



<DIR> 
<DIR> 



<DIR> 



1,816 BrowserApp. java 
4,628 Browser Frame. java 
1,780 BrowserView, java 
2,397 BrowserToolBar. java 
4,539 BrowserStatusBar . java 
1,555 BrowserMenuBar . java 
5,285 Connect Dig. java 
CVS 

2,699 FileMenu . j ava 
2,842 HelpMenu . j ava 

172 left.gif 
2,081 ListPane. java 

861 Makefile 
3,291 NumberField. java 

172 right.gif 
2,326 TreePane. java 
1,310 Utility. java 
3,722 ViewMenu. java 
1,388 ViewTypes . java 
42,864 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\browser\ui\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06: 18p 

6 File(s) 



<DIR> 
<DIR> 



923 Entries 
46 Repository 
4 6 Root 

846 Template 
1,861 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\browser \util 



12/06/00 04:33p 

12/06/00 04:33p 

12/07/99 04:25p 

12/06/00 04:33p 

12/07/99 04:25p 



<DIR> 
<DIR> 

<DIR> 



2,687 Application. java 
CVS 

8, 388 DefaultResourceVisitor . java 
Page 9 



iz/u //yy 


04 


: z5p 


1 o /m / on 
Iz/ U 1/33 


U4 


: z5p 


iz/0 //yy 


04 


: 25p 


12/07/99 


04 


: 25p 


12/15/99 


04 


: OOp 


iz/ u / / y y 




: z5p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 



16 File(s: 



test 

5,278 ExternalResource . java 

2, 667 FrameworkVocabulary . j ava 

1,517 FrameworkExcept ion. java 

3,131 FrameworkContext . java 

878 Makefile 

11,438 PrintResourceVisitor. java 

2,484 PrintTreeFactory. java 

2,981 ResourceVisitor . java 

5 , 682 ResourceProvider . j ava 

5,381 ResourceDiscover . java 

3,180 VocabularyFinder . java 
55,692 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\browser\util\C 
VS 



12/06/00 
312/06/00 
012/16/99 
^12/16/99 
A^12/16/99 
f 12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06: 18p 
5 



<DIR> 
<DIR> 



Filefs' 



753 Entries 
4 8 Repository 
46 Root 

846 Template 
1,693 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\CVS 



';l2/06/00 
fl2/06/00 
fl2/16/99 
fl2/16/99 
fl2/16/99 
=12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06: 18p 
06: 18p 
7 



<DIR> 
<DIR> 



File (s) 



48 Entries 
63 Entries. Log 
35 Repository 
4 6 Root 
84 6 Template 
1,038 bytes 



Directory of E:\e-speak-src_991217\platforra\ES\contrib\gsysmon 



12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


: 25p 




5,116 BarSurf ace. java 


12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/07/99 


04 


: 25p 




1,806 Graphlntf . java 


12/07/99 


04 


: 25p 




7,034 GraphSurf ace. java 


12/15/99 


04 


:00p 




533 Makefile 


12/07/99 


04 


:25p 




8,4 39 SysMonGui . java 


12/07/99 


04 


:25p 




7,198 TGFrarae.java 






9 


File(s) 


30,126 bytes 
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test 

Directory of E:\e-speak-src_991217\platform\ES\contrib\gsysmon\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 305 Entries 

12/16/99 06:18p 43 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File (s) 1,240 bytes 

Directory of E:\e-speak-src_991217\platform\ES\contrib\sysmon 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 386 Makefile 

^^12/07/99 04:25p 8, 877 SysMon.java 

J 5 File(s) 9,263 bytes 

I Directory of E:\e-speak-src_991217\platform\ES\contrib\sysmon\CVS 



:£12/06/00 


04:33p 




<DIR> 




:=^n2/06/00 


04:33p 




<DIR> 




:!:i2/16/99 


06:18p 






96 Entries 


^"12/16/99 


06: 18p 






42 Repository 


:\12/16/99 


06: ISp 






4 6 Root 


;r:i2/i6/99 


06: 18p 






84 6 Template 




6 


File(s) 


1,030 bytes 


Directory of E:' 


\e- 


■speak-src 


991217 \platform\ES\contrib\vfs 


'n2/06/00 


04:33p 




<DIR> 




12/06/00 


04:33p 




<DIR> 




12/06/00 


04:33p 




<DIR> 


conf ig 


12/06/00 


04:33p 




<DIR> 


CVS 


12/06/00 


04:33p 




<DIR> 


src 




5 


File (s) 


0 bytes 


Directory of E:\e- 


speak-src 


991217 \platform\ES\contrib\vfs\config 


12/06/00 


04:33p 




<DIR> 




12/06/00 


04:33p 




<DIR> 




12/07799 


04:25p 






20 col 


12/07/99 


04:25p 






20 co2 


12/06/00 


04:33p 




<DIR> 


CVS 


12/07/99 


04:25p 






2,895 Makefile 


12/07/99 


04:25p 






1,147 Makefile.bat 


12/07/99 


04:25p 






135 VFSBrowser.ini 



Page 11 



12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

13 File(s) 



test 

272 VFSBrowser.prop 
147 VFSFileStore.ini 
448 VFSFileStore.prop 
137 VFSShell.ini 
272 VFSShell.prop 
5,493 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\vf s\conf ig\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06: 18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s; 



486 Entries 
4 6 Repository 
4 6 Root 

84 6 Template 
1,424 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\vfs\CVS 



U2/06/00 
^12/06/00 
^12/16/99 
'12/16/99 
;12/16/99 
^2/16/99 
,12/16/99 



04: 33p 
04:33p 
06: 18p 
06: 18p 
06:18p 
06:18p 
06: 18p 
7 



<DIR> 
<DIR> 



File(s) 



3 Entries 
29 Entries. Log 
39 Repository 
46 Root 
846 Template 
963 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\vfs\src 



fl2/06/00 04:33p <DIR> 
^12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
4 File(s) 



CVS 
vf s 
0 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\vf s\src\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06:18p 
06:18p 

7 File(s) 



<DIR> 
<DIR> 



3 Entries 
13 Entries. Log 
43 Repository 
4 6 Root 
84 6 Template 
951 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\vfs\src\vfs 
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test 



12/06/00 


04 


: 33p 


<DIR> 


• 


12/06/00 


04 


: 33p 


<DIR> 


• • 


12/06/00 


04 


: 33p 


<DIR> 


browser 


12/06/00 


04 


: 33p 


<DIR> 


clientap 


IZ/Ub/UU 


A A 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


intf 


12/07/99 


04 


:25p 




450 Makefile 


12/06/00 


04 


: 33p 


<DIR> 


server 


12/06/00 


04 


: 33p 


<DIR> 


shell 


12/06/00 


04 


:33p 


<DIR> 


util 






10 


File (s) 


450 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\br 
owser 



,.12/06/00 


04:33p 


<DIR> 


^-12/06/00 


04:33p 


<DIR> 


;^fl2/07/99 


04:25p 


4,924 


,112/07/99 


04:25p 


31,720 


:^^12/07/99 


04:25p 


2, 616 


:Sl2/07/99 


04:25p 


25,061 


;":12/07/99 


04:25p 


472 


!r;i2/07/99 


04:25p 


106,734 


^■'12/07/99 


04:25p 


4,296 


^12/07/99 


04:25p 


7,855 


;=ll2/07/99 


04 : 25p 


11,116 


:ifl2/06/00 


04:33p 


<DIR> 


;Sl2/07/99 


04:25p 


2,476 


;2.12/07/99 


04 :25p 


1, 614 


;5l2/07/99 


04:25p 


6,742 


^=12/07/99 


04:25p 


9, 936 


12/07/99 


04:25p 


7, 950 


12/06/00 


04: 33p 


<DIR> 


12/07/99 


04:25p 


7,139 


12/07/99 


04:25p 


10,419 


12/07/99 


Q4:25p 


1, 120 


12/07/99 


04:25p 


5,151 


12/07/99 


04:25p 


15,865 


12/07/99 


04:25p 


10,893 


12/07/99 


04:25p 


6,824 


12/07/99 


04:25p 


41,781 


12/07/99 


04;25p 


5,214 


12/07/99 


04:25p 


11,054 


12/07/99 


04:25p 


10,326 


12/07/99 


04:25p 


3,472 


12/07/99 


04:25p 


235, 548 


12/07/99 


04:25p 


1,805 



AttributeViewListener . j ava 
AttributeView . j ava 
Attributeltem. java 
Browser. java 
Browser . resources 
BrowsePane . j ava 
BrowsePane . resources 
BrowseDialog . j ava 
CabinetAttr ibutesDialog . j ava 
CVS 

DirectoryNode . j ava 
DragData, java 
Filelnfo. java 
FileStoreListDialog. java 
FolderWatcher . j ava 
images 

Input Dialog. java 
LaunchFile . java 
Makefile 

MessageBoxOnTop . j ava 
NewFileDialog . j ava 
ProgressDialog. java 
PropertiesDialog. java 
SearchPane . j ava 
SearchPane . resources 
SelectCabinetDialog. java 
SelectCabinetDialog. resources 
SplashScreen. java 
SplashScreen . resources 
SysImageList .java 
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test 

12/07/99 04:25p 7,510 TreeWatcher . java 

33 File(s) 597,633 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\br 
owser\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 
7 



<DIR> 
<DIR> 



File(s) 



1,610 
16 
55 
46 
846 
2,573 



Entries 
Entries .Log 
Repository 
Root 

Template 
bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\vf s\src\vf s\br 
owser\images 



^^12/06/00 


04 


:33p <DIR> 






;^12/06/00 


04 


:33p <DIR> 






W12/06/00 


04 


:33p <DIR> 




CVS 


^12/07/99 


04 


:25p 


9, 484 


FILECOPY.AVI 


'=^2/07/99 


04 


:25p 


1,238 


HPLogo.bmp 


i!'l2/07/99 


04 


: 25p 


766 


LCabClose. ICO 


^^^2/07/99 


04 


: 25p 


766 


LCabOpen. ICO 


f. 12/07/99 


04 


:25p 


766 


LFile. ICO 


i:';i2/07/99 


04 


:25p 


766 


LFLDClose.ICO 


■ifl2/07/99 


04 


:25p 


766 


LFLDOpen. ICO 


:.ril2/07/99 


04 


:25p 


318 


SCabClose. ICO 


:^12/07/99 


04 


: 25p 


318 


SCabOpen. ICO 


yi2/07/99 


04 


:25p 


20,796 


SEARCH.AVI 


'=-^12/07/99 


04 


:25p 


318 


SFile. ICO 


12/07/99 


04 


:25p 


318 


SFLDClose. ICO 


12/07/99 


04 


:25p 


318 


SFLDOpen. ICO 






16 File(s) 


36, 938 


bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\br 
owser\images\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06: 18p 
6 



<DIR> 
<DIR> 



File (s) 



634 Entries 
62 Repository 
4 6 Root 

84 6 Template 



1,588 bytes 

Directory of E: \e-speak-src_991217\platform\ES\contrib\vf s\src\vfs\cl 
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test 



ientapi 








12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04 :33p 


<DIR> 




12/07/99 


04 :25p 






12/07/99 


04 :25p 




2, 


12/07/99 


04 :25p 




5, 


12/07/99 


04 :25p 




26, 


12/07/99 


04 :25p 




8, 


12/07/99 


04:25p 




10, 


12/07/99 


04:25p 




1, 


12/07/99 


04 :25p 




4, 


12/07/99 


04 :25p 




26, 


12/07/99 


04:25p 




10, 


12/07/99 


04:25p 




5, 


12/07/99 


04:25p 




28, 




15 


File (s) 


130 


Directory of E:\e-speak-src 


991217 


ientapiXCVS 






12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/16/99 


06:18p 






12/16/99 


06:18p 






12/16/99 


06:18p 






12/16/99 


06:18p 








6 


File(s) 


1 



:£ Directory of E:\e-speak-src_991217 



CVS 

707 Makefile 

021 NoFileStoreFoundException. java 

825 VFSFileStoreContract . java 

093 VFSFileCabinet. java 

312 VFSFileStoreVocabulary. java 

222 VFSFileStoreFinder. java 

969 VFSFileStoreElement. java 

040 VFSFileStoreDescription. java 

604 VFSFolder. java 

343 VFSResourceVocabulary . java 

781 VFSResourceContract . java 

252 VFSWorkSpace. java 

,169 bytes 

\platform\ES\contrib\vf s\src\vf s\cl 



712 Entries 

57 Repository 

4 6 Root 
84 6 Template 
, 661 bytes 

\platform\ES\contrib\vf s\src\vf s\CV 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 48 Entries 

12/16/99 06:18p 95 Entries. Log 

12/16/99 06:18p 47 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,082 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\vf s\src\vf s\in 
tf 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 
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12/07/99 


04 


: 25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


: 25p 


12/07/99 


04 


:25p 


. java 






12/07/99 


04 


: 25p 



10 File(s: 



test 

556 Makefile 
5,670 VFSFilelntf . java 
1, 849 VFSFilelntfMessageRegistry. java 
10,400 VFSFileStub. java 
8,982 VPS FileStoreStub. java 
2, 223 VFSFileStorelntfMessageRegistry 

4,145 VFSFileStorelntf . java 
33,825 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\in 
tf\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
'12/16/99 
■12/16/99 



04:33p 
04:33p 
06: 18p 
06:18p 
06:18p 
06:18p 

6 File(s) 



<DIR> 
<DIR> 



411 Entries 

52 Repository 

4 6 Root 

846 Template 



1,355 bytes 

Directory of E: \e-speak-src_991217\platform\ES\contrib\vf s\src\vf s\se 



l^rrver 












^^'12/06/00 


04 


: 33p 


<DIR> 






ra2/06/00 


04 


: 33p 


<DIR> 






1^12/06/00 


04 


: 33p 


<DIR> 




CVS 


;^12/07/99 


04 


:25p 




9, 327 


DumpVFSEntries . j ava 


;5l2/15/99 


04 


:00p 




542 


Makefile 


;5l2/07/99 


04 


:25p 




5,319 


StartFileStore. java 


;5:i2/07/99 


04 


: 25p 




10, 836 


VFSFileStoreService. java 


'""12/07/99 


04 


:25p 




25, 820 


VFSFileStorelmpl . j ava 


12/07/99 


04 


:25p 




13,228 


VFSFilelmpl. java 






9 File 


(s) 


65,072 


1 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\vf s\src\vf s\se 
rver\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06: 18p 
06: 18p 
06: 18p 
06:18p 

6 File(s) 



<DIR> 
<DIR> 



332 Entries 
54 Repository 
4 6 Root 

846 Template 
1,278 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\vfs\src\vfs\sh 
ell 
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test 



12/06/00 


04 : 33p 


<DIR> 




12/06/00 


04 :33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/07/99 


04:25p 






12/07/99 


04:25p 




3, 


12/07/99 


04:25p 




3, 


12/07/99 


04:25p 




20, 


12/07/99 


04 :25p 




10, 


12/07/99 


04:25p 




3, 


12/07/99 


04:25p 




7, 


12/07/99 


04:25p 




5, 


12/07/99 


04:25p 




12, 


12/07/99 


04:25p 




8, 


12/07/99 


04:25p 




10, 


12/07/99 


04:25p 




5, 


..,12/07/99 


04:25p 




6, 


O12/07/99 


04:25p 




14, 


:Ol2/07/99 


04:25p 




2, 


'^n2/07/99 


04:25p 




4, 


i«12/07/99 


04:25p 




10, 


^ifl2/07/99 


04:25p 




6, 


!=^12/07/99 


04:25p 




5, 


i!:i2/07/99 


04:25p 




5, 


^^^12/07/99 


04:25p 




1, 


',12/07/99 


04:25p 




15, 


i!:i2/07/99 


04:25p 




7, 


1^12/07/99 


04:25p 




1, 


^n;12/07/99 


04:25p 




3, 




28 


File (s) 


179 



" Directory of E:\e-speak-src_991217 
ellXCVS 



CVS 

967 Makefile 
469 VFScatCommand. java 
830 VFScdCommand. java 
179 VFSCommand. java 
028 VFScpCommand. java 
111 VFSechoCommand. java 
278 VFSexecCortimand. java 
660 VFSexportCoinniand. java 
226 VFSf indCommand. java 
167 VFSimport Command. java 
912 VFS Is Command. java 
754 VFSmkdirCommand. java 
212 VFSmkf ileCommand. java 
992 VFSmvCommand . j a va 
901 VFSpwdCommand. java 
576 VFSresetCommand. java 
724 VFS rmCommand. java 
855 VFS rmdirCommand. java 
909 VFS setCommand. java 
986 VFS shareCommand. java 
776 VFSShellException. java 
496 VFSShell. java 
593 VFS showCommand. java 
775 VFSStackExcept ion. java 
280 VFSStack. java 
, 656 bytes 

\platform\ES\contrib\vfs\src\vfs\sh 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 1,379 Entries 

12/16/99 06:18p 53 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 2,324 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\ut 
il 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 
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12/07/99 04:25p 
12/07/99 04:25p 

5 File(s) 



test 

401 Makefile 
3,469 VFSStrings. java 
3,870 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\vf s\src\vf s\ut 
il\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06: 18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



100 Entries 
52 Repository 
4 6 Root 

84 6 Template 
1,044 bytes 



Directory of E:\e-speak-src_991217\platforin\ES\CVS 



?12/06/00 
fl2/06/00 
^2/16/99 
h2/16/99 
il2/16/99 
^12/16/99 
:i2/16/99 



04:33p 
04:33p 
06: 17p 
06:22p 
06:17p 
06: 17p 
06: 17p 
7 



<DIR> 
<DIR> 



File (s) 



431 Entries 
110 Entries. Log 

27 Repository 

4 6 Root 
84 6 Template 
1,460 bytes 



Directory of E:\e-speak-src_991217\platform\ES\extern 



:i2/06/00 
112/06/00 
?12/06/00 
12/06/00 
12/05/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04 : 33p 
04:33p 
6 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 
Idap 
openxml 
oracle-lib 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\extern\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06: 18p 
06:18p 
06: 18p 
06: 18p 
06: 18p 
7 



<DIR> 
<DIR> 



File (s) 



3 Entries 
51 Entries. Log 
34 Repository 
46 Root 
84 6 Template 
980 bytes 



Directory of E:\e-speak-src_991217\platform\ES\extern\ldap 
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test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 

12/08/99 01:52p 160,475 Idapjdk. jar 

4 File(s) 160,475 bytes 

Directory of E:\e-speak-src_991217\platform\ES\extern\ldap\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 51 Entries 

12/16/99 06:18p 39 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 982 bytes 

^-3 Directory of E:\e-speak-src_991217\platform\ES\extern\openxml 

^"^^12/06/00 04:33p <DIR> 
;^12/06/00 04:33p <DIR> 
;£fl2/06/00 04:33p <DIR> CVS 

:=fl2/08/99 01:49p 357,071 openxml.jar 

4 File(s) 357,071 bytes 

Directory of E:\e-speak-src_991217\platform\ES\extern\openxml\CVS 

:il2/06/00 04:33p <DIR> 

:^12/06/00 04:33p <DIR> 

:±il2/16/99 06:18p 51 Entries 

:ffl2/16/99 06:18p 42 Repository 

^===12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 985 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\extern\oracle-lib 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/08/99 01:57p 800,174 classeslll.zip 

12/06/00 04:33p <DIR> CVS 

4 File(s) 800,174 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\extern\oracle-lib\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 54 Entries 
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test 

12/16/99 06:18p 45 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File{s) 991 bytes 



Directory of E:\e-speak-src_991217\platform\ES\sainples 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


:33p 


<DIR> 


echo 


12/06/00 


04 


: 33p 


<DIR> 


ESChat 


12/07/99 


04 


:25p 




290 Makefile 


12/06/00 


04 


:33p 


<DIR> 


ManagedEcho 


12/06/00 


04 


: 33p 


<DIR> 


ManagedPrint Server 


12/06/00 


04 


: 33p 


<DIR> 


PrintServer 






9 


File (S) 


290 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples\CVS 



^^2/06/00 


04:33p <DIR> 




12/05/00 


04:33p <DIR> 




3l2/16/99 


06:18p 


48 Entries 


12/16/99 


06:19p 


100 Entries. Log 


^^12/16/99 


06:18p 


35 Repository 


' 12/16/99 


06:18p 


46 Root 


r: 12/16/99 


06:18p 


84 6 Template 




7 File(s) 


1,075 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples\echo 



='12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


conf ig 


12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/07/99 


04 


:25p 




4,998 echo.vjp 


12/07/99 


04 


:25p 




4,127 README.txt 


12/06/00 


04 


: 33p 


<DIR> 


src 






7 


File (s) 


9,125 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\samples\echo\conf ig 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:25p 25 col.MYCO 

12/07/99 04:25p 26 co2.MYC0 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> raulticore 
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12/06/00 04:33p <DIR> 
7 File(s) 



test 

singlecore 
51 bytes 



Directory of E: \e-speak-src_991217\platform\ES\samples\echo\conf ig\CV 

S 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 93 Entries 

12/16/99 06:19p 39 Entries. Log 

12/16/99 06:19p 47 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,071 bytes 

Directory of E : \e-speak-src_991217\platform\ES\samples\echo\conf ig\mu 



<DIR> 
<DIR> 

64 client. prop 

<DIR> CVS 

744 EchoClient.ini 

730 EchoServer.ini 

42 server. prop 
,, 7 File(s) 1, 580 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\echo\config\inu 
Slticore\CVS 

=12/06/00 04:33p <DIR> 
^12/06/00 04:33p <DIR> 

12/16/99 06:19p 201 Entries 

12/16/99 06:19p 57 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,150 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\echo\conf ig\si 
nglecore 



^Iticore 






:%2/06/00 


04 


: 33p 


.112/06/00 


04 


: 33p 


:%2/07/99 


04 


:25p 


:ifl2/06/00 


04 


: 33p 


;=::i2/07/99 


04 


: 25p 


:r;i2/07/99 


04 


: 25p 


^^'12/07/99 


04 


:25p 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:25p 




60 


client . prop 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




199 


EchoClient . ini 


12/07/99 


04 


:25p 




328 


EchoServer . ini 


12/07/99 


04 


:25p 




60 


server .prop 
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7 File(s) 



test 

647 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples\echo\config\si 
nglecore\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 201 Entries 

12/16/99 06:19p 58 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,151 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\echo\CVS 



12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




□ 12/16/99 


06:19p 




95 


:Ol2/16/99 


06:19p 




29 


■"^12/16/99 


06:19p 




40 


:«12/16/99 


06:19p 




46 


^ff 12/16/99 


06: 19p 




846 



7 File(s) 1,056 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\echo\src 



;:; 12/0 6/00 


04:33p 


<DIR> 




;ii2/06/oo 


04:33p 


<DIR> 




r:i2/06/oo 


04:33p 


<DIR> 




:i:12/07/99 


04:25p 




5,216 


-12/07/99 


04:25p 




6,205 


^''■■12/07/99 


04:25p 




2, 397 


12/07/99 


04:25p 




3, 838 


12/07/99 


04:25p 




1,388 


java 








12/07/99 


04:25p 




2,397 


12/07/99 


04:25p 




2, 103 


12/07/99 


04:25p 




22,016 


12/07/99 


04:25p 




661 



CVS 

EchoServer . j ava 
EchoClient . j ava 



12 File(s) 46,221 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\echo\src\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 501 Entries 

12/16/99 06:19p 44 Repository 

12/16/99 06:19p 46 Root 
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test 

12/16/99 06:19p 846 Template 

6 File(s) 1,437 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\ESChat 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> config 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 3,550 README.txt 

12/06/00 04:33p <DIR> src 

6 File(s) 3,550 bytes 

Directory of E : \e-speak:-src_991217\platf orm\ES\samples\ESChat\conf ig 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

312/06/00 04:33p <DIR> CVS 

D12/06/00 04:33p <DIR> multicore 

^a2/05/00 04:33p <DIR> singlecore 

^ 5 File(s) 0 bytes 

=^ Directory of E:\e-speak-src_991217\platform\ES\samples\ESChat\config\ 

==cvs 

.12/06/00 04:33p <DIR> 

:il2/06/00 04:33p <DIR> 

ifl2/16/99 06:18p 3 Entries 

512/16/99 06:18p 39 Entries. Log 

212/16/99 06:18p 49 Repository 

fl2/16/99 06:18p 46 Root 

"=12/16/99 06:18p 846 Template 

7 File(s) 983 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\ESChat\conf ig\ 
multicore 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


: 25p 




58 client. pr 


12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/07/99 


04 


:25p 




757 ESChatServer.ini 


12/07/99 


04 


: 25p 




164 ESChatClient.ini 


12/07/99 


04 


: 25p 




570 ESChatAddCore.ini 


12/07/99 


04 


: 25p 




58 server. pr 






8 


File (s) 


1, 607 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\samples\ESChat \conf ig\ 
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multicoreXCVS 



test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 255 Entries 

12/16/99 06:18p 59 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File{s) 1,206 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\ESChat\conf 
singlecore 



12/06/00 


04: 33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/07/99 


04:25p 




57 


_.12/06/00 


04:33p 


<DIR> 




012/07/99 


04:25p 




740 


:Dl2/07/99 


04:25p 




204 


^"=^12/07/99 


04:25p 




57 




7 


File (s) 


1,05 



CVS 

ESChatServer . ini 



^ Directory of E:\e-speak-src_991217\platform\ES\samples\ESChat\conf 
„;singlecore\CVS 

\12/06/00 04:33p <DIR> 
::i2/06/00 04:33p <DIR> 

i:i2/16/99 06:18p 201 Entries 

5:12/16/99 06:18p 60 Repository 

212/16/99 06:18p 46 Root 

412/16/99 06:18p 846 Template 

6 File(s) 1,153 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\ESChat\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 50 Entries 

12/16/99 06:18p 29 Entries. Log 

12/16/99 06:18p 42 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,013 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\ESChat\src 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
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test 



12/07/99 


04 


0 r- 

: 25p 




3, 


466 


ChatEventDist . j ava 


Iz / U b/ U U 


U4 


: 0 Jp 


<DIK> 






CVS 


12/07/99 


04 


:25p 




23, 


040 


ESChatUML.doc 


12/07/99 


04 


:25p 




9, 


527 


ESChat . java 


12/07/99 


04 


:25p 






404 


Makefile 


12/07/99 


04 


:25p 




3, 


219 


MessageDialog . j ava 


12/07/99 


04 


: 25p 




3, 


185 


Subscriberlmpl . j ava 



9 File(s) 42,841 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\samples\ESChat\src\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 312 Entries 

12/16/99 06:18p 46 Repository 

12/16/99 06:18p 46 Root 

^12/16/99 06:18p 846 Template 

J 6 File(s) 1,250 bytes 

j Directory of E:\e-speak-src_991217\platforra\ES\samples\ManagedEcho 

!l2/06/00 04:33p <DIR> 

'12/06/00 04:33p <DIR> 

;i2/06/00 04:33p <DIR> config 

'12/06/00 04:33p <DIR> CVS 

^12/07/99 04:25p 2,236 README.txt 

;i2/06/00 04:33p <DIR> src 

[ 6 File(s) 2,236 bytes 

I Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedEcho\co 

Inf ig 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:25p 25 col.MYCO 

12/07/99 04:25p 26 co2.MYC0 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 443 ManagedEcho.ini 

12/07/99 04:25p 108 testMgr.ini 

7 File(s) 602 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\iyianagedEcho\co 
nfigXCVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 193 Entries 

12/16/99 06:18p 54 Repository 
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test 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,139 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedEcho\CV 

S 

<DIR> 
<DIR> 

50 Entries 
29 Entries. Log 
47 Repository 
46 Root 
846 Template 
File(s) 1,018 bytes 



12/06/00 


04: 


33p 


12/06/00 


04: 


33p 


12/16/99 


06: 


18p 


12/16/99 


06: 


18p 


12/16/99 


06: 


18p 


12/16/99 


06: 


18p 


12/16/99 


06: 


18p 
7 


_ Directory of 


■ E: 


■'=*12/06/00 


04: 


33p 


12/06/00 


04: 


33p 


^i^l2/06/00 


04: 


33p 


^12/07/99 


04: 


25p 


!::i2/07/99 


04 : 


25p 


^'""^12/07/99 


04 : 


25p 


. java 






i!:i2/07/99 


04: 


25p 


:ifl2/07/99 


04: 


25p 


:Sl2/07/99 


04: 


25p 


:El2/07/99 


04: 


25p 


:f 12/07/99 


04: 


25p 


^^'12/07/99 


04: 


25p 



<DIR> 
<DIR> 

<DIR> CVS 

2,212 EchoServicelntf .esidl 
2,343 EchoServiceStub. java 
1,408 EchoServicelntfMessageRegistry . 

2,216 EchoServicelntf . java 

2,154 EchoServicelmpl . java 

688 Makefile 

6,077 ManagedEcho. java 

2,632 startManagedEcho. java 

4,196 testMgr . java 
12 File(s) 23,926 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\ManagedEcho\sr 
c\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 05:18p 509 Entries 

12/16/99 06:18p 51 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,452 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver 
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test 



12/05/00 


04 


: 33p 


<DIR> 


• 


lz/06/00 


04 


: 33p 


<DIR> 




lz/06/00 


04 


: 33p 


<DIR> 


conf ig 




n 4 

U 4 


• ^-r\ 
. ^ jp 


<U1K> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


doc 


12/09/99 


06 


:44a 




5,800 README.txt 


12/06/00 


04 


: 33p 


<DIR> 


SampleFiles 


12/05/00 


04 


: 33p 


<DIR> 


src 






8 File(s] 




5,800 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\sainples\ManagedPrintSe 
rver\conf ig 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


multicore 


P 12/07/99 


04 


:25p 




380 Print.ini 


12/06/00 


04 


: 33p 


<DIR> 


singlecore 






6 


File (s) 


380 bytes 



: Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
rver\conf ig\CVS 

^12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

: 12/16/99 06:18p 49 Entries 

: 12/16/99 06:18p 39 Entries. Log 

: 12/16/99 06:18p 61 Repository 

; 12/16/99 06: 18p 46 Root 

; 12/16/99 06:18p 846 Template 

7 File(s) 1,041 bytes 

Directory of E: \e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
rver\conf igXmulticore 



12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


: 25p 




12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


:25p 




12/07/99 


04 


:25p 




12/09/99 


07 


:02a 





7 File(s) 



Directory of E:\e-spealc-src_99 
rver\conf igXmulticore \CVS 



42 Client. prop 
CVS 
341 PC.ini 
538 PC-Core. ini 
1,696 PS. ini 
2,617 bytes 

17\platform\ES\samples\ManagedPrintSe 
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12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:25p 




12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


:25p 




12/07/99 


04 


:25p 




□ 12/09/99 


07 


: 03a 




12/07/99 


04 


:25p 





test 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 185 Entries 

12/16/99 06:18p 71 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,148 bytes 

Directory of E: \e-spealc-src_991217\platform\ES\saiaples\ManagedPrintSe 
rver\conf igXsinglecore 



42 Client. prop 
CVS 
220 PC.ini 
376 print.ini 
1,278 PS.ini 

42 Server. prop 
\ 8 File(s) 1,958 bytes 

I Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
rver\conf ig\singlecore\CVS 

h2/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

:i2/16/99 06:18p 231 Entries 

fl2/16/99 06:18p 72 Repository 

fl2/16/99 06:18p 46 Root 

^12/16/99 06:18p 846 Template 

; 6 File(s) 1,195 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 50 Entries 

12/16/99 06:18p 63 Entries. Log 

12/16/99 06:18p 54 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,059 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\saraples\ManagedPrintSe 
rver\doc 

12/06/00 04:33p <DIR> 
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12/06/00 
12/06/00 
12/09/99 



04 :33p 
04:33p 
07:01a 
4 



<DIR> 
<DIR> 



File(s) 



test 

CVS 

96,647 Userguide.doc 
96,647 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\doc\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



53 Entries 
58 Repository 
4 6 Root 
84 6 Template 
1,003 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
; rver\SampleFiles 



^12/06/00 
: 12/06/00 
^12/06/00 
^12/07/99 
;i2/G7/99 
^12/07/99 
12/07/99 
;i2/07/99 



04:33p 
04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

8 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

181,760 test. doc 
351 test.ini 
6 test.ppt 
49 test.txt 
6 test.xls 
182,172 bytes 



;: Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
;:rver\SarapleFiles\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06: 18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



228 Entries 
66 Repository 
4 6 Root 

84 6 Template 
1,186 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\src 



12/06/00 
12/06/00 
12/06/00 
12/15/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04: OOp 
04:25p 



<DIR> 
<DIR> 
<DIR> 



CVS 

799 Makefile 
10,298 ManagedPrintService. java 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04 :25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
12 



File (s) 



test 

6,133 Policy-Writer , java 
18,611 PrintClient . java 

3,805 PrinterStub. java 

1,884 Printerlntf . java 
14,133 Printerlitipl . java 

5,539 Print Joblnfo. java 
18,441 PrintServer. java 

79,643 bytes 



Directory of E: \e-speak-src_991217\platfonn\ES\samples\ManagedPrintSe 
rver\src\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 482 Entries 

12/16/99 06:18p 58 Repository 

.12/16/99 06:18p 46 Root 

fl2/16/99 06:18p 846 Template 

^ 6 File(s) 1,432 bytes 

^ Directory of E:\e-speak-src_991217\platform\ES\saraples\PrintServer 

^12/05/00 04:33p <DIR> 

:i2/06/00 04:33p <DIR> 

^2/06/00 04:33p <DIR> config 

.12/06/00 04:33p <DIR> CVS 

:i2/07/99 04:25p 4,499 README.txt 

;12/06/00 04:33p <DIR> SampleFiles 

;l2/06/00 04:33p <DIR> src 

j 7 File(s) 4,499 bytes 

' Directory of E:\e-speak-src_991217\platform\ES\samples\PrintServer\co 
nf ig 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 




col 


12/06/00 


04 


:33p 


<DIR> 




co2 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/06/00 


04 


:33p 


<DIR> 




multicore 


12/07/99 


04 


:25p 




297 


Print . ini 


12/07/99 


04 


:25p 




1, 973 


printer . xinl 


12/07/99 


04 


:25p 




1, 688 


printerl.xml 


12/07/99 


04 


:25p 




1, 760 


printit .pi 


12/07/99 


04 


: 25p 




1,571 


printVocab.xml 


12/06/00 


04 


: 33p 


<DIR> 




singlecore 






12 


File(s) 


7,289 bytes 
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test 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nf ig\col 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 25 col.MYCO 

12/06/00 04:33p <DIR> CVS 

4 File(s) 25 bytes 

Directory of E: \e-speak-src_991217\platforin\ES\samples\PrintServer\co 
nfig\col\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 48 Entries 

12/16/99 06:18p 58 Repository 

.12/16/99 06:18p 46 Root 

312/16/99 06:18p 846 Template 
^ 6 File(s) 998 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\PrintServer\co 
jfnf ig\co2 

^12/06/00 04:33p <DIR> 

^12/06/00 04:33p <DIR> 

.12/07/99 04:25p 25 co2.MyC0 

^12/06/00 04:33p <DIR> CVS 

i{ 4 File(s) 25 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\PrintServer\co 
=:nfig\co2\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 48 Entries 

12/16/99 06:18p 58 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 998 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nfigXCVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 244 Entries 

12/16/99 06:18p 65 Entries. Log 

12/16/99 06:18p 54 Repository 
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test 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,255 bytes 

Directory of E : \e-speak-src_991217\platform\ES\samples\PrintServer\co 



nf igXmulticore 




12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/07/99 


04:25p 


42 Client. prop 


12/06/00 


04:33p <DIR> 


CVS 


12/07/99 


04:25p 


202 PC.ini 


12/07/99 


04:25p 


557 PC-Core. ini 


12/07/99 


04:25p 


817 PS. ini 




7 File(s) 


1, 618 bytes 


Directory of E:\e-speak-src 


991217\platform\ES\samples\PrintServer\co 


nf ig\multicore\CVS 


12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:18p 


185 Entries 


12/16/99 


06:18p 


64 Repository 


12/16/99 


06:18p 


4 6 Root 


12/16/99 


06:18p 


846 Template 




6 File(s) 


1,141 bytes 



j Directory of E:\e-speak-src_991217\platform\ES\samples\PrintServer\co 
: nf ig\singlecore 

:12/06/00 04:33p <DIR> 
^'12/06/00 04:33p <DIR> 

12/07/99 04:25p 42 Client. prop 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 184 PC.ini 

12/07/99 04:25p 426 PS . ini 

6 File(s) 652 bytes 

Directory of E: \e-speak-src_991217\platform\ES\samples\PrintServer\co 
nf ig\singlecore\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 137 Entries 

12/16/99 06:18p 65 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,094 bytes 
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test 



12/06/00 


04 


: 33p 


<DIR> 


O12/O6/OO 


04 


:33p 


<DIR> 


* 12/06/00 


04 


:33p 


<DIR> 




04 


: 25p 




:^12/07/99 


04 


:25p 




;f!l2/07/99 


04 


:25p 




:=f 12/07/99 


04 


:25p 




^!':i2/07/99 


04 


: 25p 





Directory of E: \e-speak-src_991217\platform\ES\samples\PrintServer\CV 

S 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 50 Entries 

12/16/99 06:18p 50 Entries. Log 

12/16/99 06:18p 47 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File (3) 1,039 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\saraples\PrintServer\Sa 
mpleFiles 



CVS 

181,760 test. doc 
351 test.ini 
6 test.ppt 
4 9 test.txt 
6 test.xls 
8 File(s) 182,172 bytes 

! Directory of E:\e-speak-src_991217\platform\ES\samples\PrintServer\Sa 
;rapleFiles\CVS 

?12/06/00 04:33p <DIR> 
fl2/06/00 04:33p <DIR> 

=12/16/99 06:18p 228 Entries 

12/16/99 06:18p 59 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,179 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\sainples\PrintServer\sr 

c 



CVS 

995 Makefile 
6,152 PrintServer . java 
16,750 PrintClient. java 
2,375 Print Joblnfo. esidl 
2,524 Print Joblnfo. java 
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12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/15/99 


04 


: OOp 




12/07/99 


04 


:25p 




12/07/99 


04 


:25p 




12/07/99 


04 


:25p 




12/07/99 


04 


:25p 





test 



12/07/99 


04 : 25p 


60, 928 


lz/07/99 


04 : 25p 


2, 343 


12/07/99 


04:25p 


2,958 


12/07/99 


04:25p 


1,574 


. j ava 






12/07/99 


04 :25p 


2, 347 


12/07/99 


04:25p 


6,187 



14 File(s) 



105,133 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\sr 
c\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:18p 
06: 18p 
06: 18p 
6 



<DIR> 
<DIR> 



File (s) 



624 
51 
46 
846 
1,567 



Entries 

Repository 

Root 

Template 
bytes 



Directory of E:\e-speak-src_991217\platform\ES\src 



1-^12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 


c 


;■ . 12/06/00 


04:33p 


<DIR> 


CVS 


;r: 12/06/00 


04:33p 


<DIR> 


java 


12/06/00 


04:33p 


<DIR> 


perl 


:rii2/o6/oo 


04:33p 


<DIR> 


python 




7 


File(s) 


0 bytes 


Directory of E: Xe-speak-src ! 


391217\platforra\ES\src\c 


12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 


cesi 


12/06/00 


04:33p 


<DIR> 


CVS 




4 


File(s) 


0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\c\cesi 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 



04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:33p 



<DIR> 
<DIR> 



<DIR> 



49,436 abi.c 
16,525 abi.h 
15,614 abi_base.c 
4,223 abi_base.h 
CVS 



Page 34 



12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:25p 
04:25p 
04:25p 
04 :25p 
04 :25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

17 File(s) 



test 
19, 827 
3,512 
620 
631 
408 
3,716 
8,036 
3,745 
5,654 
13, 071 
145,018 



eslib. c 

eslib.h 

makefile 

makef ile_w32 

README.txt 

rtc. c 

rts . c 

tc. c 

ts . c 

wservpipe , c 
bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\c\cesi\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06: 19p 

6 File(s) 



<DIR> 
<DIR> 



624 Entries 
38 Repository 
4 6 Root 
84 6 Template 
1,554 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\c\CVS 



^'-'^ 12/06/00 


04:33p <DIR> 




' 12/06/00 


04:33p <DIR> 




12/16/99 


06:19p 


3 Entries 


^Jf 12/16/99 


06:19p 


14 Entries. Log 


y 12/16/99 


06:19p 


33 Repository 


12/16/99 


06:19p 


4 6 Root 


y 12/16/99 


06:19p 


84 6 Template 




7 File(s) 


942 bytes 


Directory of E:\e-speak-src 


991217\platform\ES\src\CVS 


12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:19p 


3 Entries 


12/16/99 


06:22p 


55 Entries. Log 


12/16/99 


06:19p 


31 Repository 


12/16/99 


06:19p 


46 Root 


12/16/99 


06:19p 


846 Template 




7 File(s) 


981 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java 



12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
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test 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 187 Makefile 

12/06/00 04:33p <DIR> net 

5 File(s) 187 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 48 Entries 

12/16/99 06:19p 13 Entries. Log 

12/16/99 06:19p 36 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 989 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net 

#12/06/00 04:33p <DIR> 

;^12/06/00 04:33p <DIR> 

W12/06/00 04:33p <DIR> CVS 

1^^12/06/00 04:33p <DIR> espeak 

y 4 File(s) 0 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\CVS 



Entries 



!:':i2/06/00 


04:33p 


<DIR> 




iifl2/06/00 


04:33p 


<DIR> 




:ril2/16/99 


06:19p 




3 


12 /1 6/ 9 9 


06: 19p 




16 


:il2/16/99 


06: 19p 




40 


^==^12/16/99 


06: 19p 




46 


12/16/99 


06:19p 




846 



7 File(s) 951 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


infra 


12/06/00 


04 


:33p 


<DIR> 


jesi 


12/07/99 


04 


:25p 




477 Makefile 


12/06/00 


04 


:33p 


<DIR> 


services 


12/06/00 


04 


: 33p 


<DIR> 


util 


12/07/99 


04 


: 25p 




2,099 Version. j 


12/06/00 


04 


:33p 


<DIR> 


webaccess 






10 


File (s) 


2, 57 6 bytes 
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test 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\CV 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:21p 
06:19p 
06:19p 
06:19p 
7 



<DIR> 
<DIR> 



File (s) 



97 Entries 
80 Entries. Log 
47 Repository 
46 Root 
846 Template 
1,116 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra 



12/06/00 


04 : 33p 


<DIR> 




□12/06/00 


04:33p 


<DIR> 




«12/06/00 


04:33p 


<DIR> 


cci 


;^n2/06/00 


04:33p 


<DIR> 


client 


!^12/06/00 


04:33p 


<DIR> 


core 


^ifl2/06/00 


04 :33p 


<DIR> 


CVS 


:-^12/06/00 


04:33p 


<DIR> 


intercorecora 


:^ 12/07/99 


04:25p 




269 Makefile 


-12/06/00 


04:33p 


<DIR> 


xml 




9 


File (s) 


269 bytes 



J Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
:f ra\cci 



S12/06/00 


04 


: 33p 


<DIR> 




=-=^12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


coreapi 


12/06/00 


04 


: 33p 


<DIR> 


coreproxy 


12/06/00 


04 


:33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


events 


12/06/00 


04 


: 33p 


<DIR> 


exception 


12/06/00 


04 


: 33p 


<DIR> 


export 


12/07/99 


04 


: 25p 




357 Makefile 


12/06/00 


04 


: 33p 


<DIR> 


management 


12/06/00 


04 


: 33p 


<DIR> 


messaging 


12/06/00 


04 


: 33p 


<DIR> 


metadata 


12/06/00 


04 


:33p 


<DIR> 


naming 


12/06/00 


04 


: 33p 


<DIR> 


security 






14 


File (s) 


357 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\coreapi 
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test 



1 o i c\ r f r\c\ 


O A 

04 


o o 

: 33p 


1 o i C\ r i r\r\ 

lz/05/uO 


O /I 

04 


: 33p 


12/07/99 


O /t 

04 


O l~ 

: 25p 


12/07/99 


04 


: 25p 


12/05/00 


04 


: 33p 


12/07/99 


O /I 

04 


: 25p 


12/07/99 


O A 

04 


: 25p 


1^: / u / / y y 


O A 

04 


_ O IT 

: 25p 


12/07/99 


04 


:25p 


12/07/99 


04 


: 25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/ 07/99 


O /I 

04 


: 25p 


ava 






12/07/99 


04 


:25p 


□ 12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


■"=^12/07/99 


04 


:25p 


:«12/07/99 


04 


:25p 



<DIR> 
<DIR> 



<DIR> 



19 File(s) 



6, 485 CoreManagementlnterface. java 
8,572 CoreNames . java 
CVS 

8, 626 IraporterExporterlnterf ace. java 
2,698 Keylnterf ace. java 
4,645 KeyRinglnterf ace . java 
5,388 Mailboxinterf ace. java 

805 Makefile 
9,933 NameFramelnterf ace. java 
5, 301 Protect ionDomainlnterf ace. java 
6, 118 RepositoryViewInterf ace. java 
24, 869 ResourceManipulationlnterface. j 

3, 754 ResourceFactorylnterf ace. java 
3, 284 ResourceContractlnterf ace. java 
4,752 SystemMonitorlnterf ace. java 
5, 108 VocabularyToolboxInterf ace. java 
4,922 Vocabularylnterf ace. java 
105,260 bytes 



; Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
■ f ra\cci\coreapi\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06: 19p 
06: 19p 
06: 19p 
6 



<DIR> 
<DIR> 



File (s) 



990 
65 
46 

846 
1, 947 



Entries 

Repository 

Root 

Template 
bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\coreproxy 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 
6 



<DIR> 
<DIR> 



<DIR> 



File (s) 



6.240 Connect ionFactorylnterf ace. java 

4.241 CoreProxylnterf ace. java 
CVS 

400 Makefile 
10,881 bytes 



Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\in 
fra\cci\coreproxy\CVS 
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12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06: 19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



test 



176 Entries 
67 Repository 
46 Root 

84 6 Template 
1,135 bytes 



Directory of E:\e-spealc-src_991217\platform\ES\src\java\net\espeak\in 
fra\cci\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
^12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06: 19p 
06:19p 
06:19p 
7 



<DIR> 
<DIR> 



File (s) 



48 Entries 
178 Entries. Log 

57 Repository 

4 6 Root 
84 6 Template 
1,175 bytes 



J Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
'f ra\cci\events 



'12/06/00 
^2/06/00 
12/07/99 
:12/06/00 
h2/07/99 
^12/07/99 
^2/07/99 
^12/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 



<DIR> 
<DIR> 

<DIR> 



8 File(s) 



6,417 CoreEvent . java 
CVS 

5,7 05 EventAttributeSet . java 
7,891 EventList. java 
14,4 56 Event. java 
413 Makefile 
34,882 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\cci\events\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06: 19p 
6 



<DIR> 
<DIR> 



File (s) 



256 Entries 
64 Repository 
4 6 Root 

84 6 Template 
1,212 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\exception 



12/06/00 04:33p 



<DIR> 
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12/05/00 


04 


: 33p 


12/07/99 


04 


: 26p 


12/06/00 


04 


: 33p 


12/07/99 


04 


: 26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


::..a2/07/99 


04 


:26p 


;fil2/07/99 


04 


: 26p 


;^ll2/07/99 


04 


:26p 


UJ12/07/99 


04 


:26p 


^Uava 






312/07/99 


04 


:26p 


^^^n . java 






^1^^12/07/99 


04 


.26p 


' 12/07/99 


04 


26p 


i;:":i2/07/99 


04: 


26p 


^Jfl2/07/99 


04: 


26p 


5;;fl2/07/99 


04 : 


26p 


^^fl2/07/99 


04 : 


2 6p 


;:fl2/07/99 


04 : 


26p 


-^.2/07/99 


04: 


26p 


a 

12/07/99 


04 : 


26p 


12/07/99 


04 : 


26p 


12/07/99 


04: 


2 6p 


va 






12/07/99 


04 : 


26p 


12/07/99 


04 : 


26p 


12/07/99 


04 : 


26p 


va 






11/ 01 / 99 


04 : 


26p 


12/07/99 


04 : 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


ava 






12/07/99 


04: 


26p 


java 







<DIR> 
<DIR> 



test 

2,419 CorePanicExcept ion. java 
CVS 

2,067 EmptyMappingExcept ion. java 
8,082 ESExceptionlnfo. java 
8,668 ESException. java 
2,404 ESInvocationExcept ion. java 
1,839 ESLibException. java 
2,356 ESNameFrameException. java 
2,375 ESRemoteException. java 

7.431 ESRuntimeException. java 
2,555 ESServiceException. java 
2,458 ExportFailedException. java 
2,458 ImportFailedException. java 
2,123 InvalidValueException. java 
2,092 InvalidTypeException. java 

4. 432 InvalidParameterExcept ion. java 
2,204 InvalidNameException. java 
2,158 LookupFailedException. java 
1,585 Makefile 

2, 454 MethodNotlmplementedException. j 

2,204 MultipleResolvedBindingExceptio 

2, 094 NameCollisionException. java 

2,064 NameNotFoundExcept ion. java 

2,14 3 NamingException. java 

2, 016 NotExportableExcept ion. java 

2, 022 Not ImportableException. java 

2, 152 NullPararaeterException. java 

2, 542 Outof OrderRequestExcept ion . j ava 

2. 117 PartialStateUpdateException. jav 

2, 119 PermissionDeniedException. java 
2, 066 QuotaExhaustedException. java 
2,035 RecoverableDeliveryException. ja 

2,274 RecoverableCoreException. java 
2, 088 RepositoryFullException. java 

2. 118 RequestNotDeliveredException. ja 

2,453 ServicePanicException. java 
2,164 StaleEntryAccessException . j ava 
2,112 TimedOutException. java 
2,332 UndeliverableRequestException . j 

2,216 UnrecoverableDeliveryException. 
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test 

12/07/99 04:26p 2,009 UnresolvedBindingException . j ava 

43 File(s) 107,600 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\cci\exception\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 2,545 Entries 

12/16/99 06:19p 67 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 3,504 bytes 

Directory of E: \e-speak-src_991217\platforni\ES\src\ java\net\espeak\in 
f ra\cci\export 

O12/O6/OO 04:33p <DIR> ■ 

:Ol2/06/00 04:33p <DIR> 

^"=•^12/06/00 04:33p <DIR> CVS 

1^12/07/99 04:26p 15,693 ExportFE . java 

;£:12/07/99 04:26p 27, 068 ExportContext . j ava 

.=12/07/99 04:26p 17,102 ImportContext . java 

;::i2/07/99 04:26p 397 Makefile 

7 File(s) 60,260 bytes 

it: Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
:=^f ra\cci\export\CVS 

;5il2/06/00 04:33p <DIR> 

;=fl2/06/00 04:33p <DIR> 

^=^12/16/99 06:19p 208 Entries 

12/16/99 06:19p 64 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,164 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\management 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 368 Makefile 

12/07/99 04:26p 3,081 ManagedServiceOpcodes . java 

5 File(s) 3,449 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
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f ra\cci\management\CVS 



test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 111 Entries 

12/16/99 06: 19p 68 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

5 File(s) 1,071 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\messaging 



12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/07/99 


04:26p 




4, 


12/07/99 


04:26p 




17, 


M12/07/99 


04:26p 




23, 


fll2/07/99 


04:26p 




20, 


'"^12/07/99 


04:26p 




12, 


^=^12/06/00 


04:33p 


<DIR> 


4^12/07/99 


04:26p 




3, 


:-^12/07/99 


04:26p 




6, 


i::i2/07/99 


04:26p 




13, 


^%2/07/99 


04:26p 




9, 


r_12/07/99 


04:26p 




7, 


l!:i2/07/99 


04:26p 




2, 


!]fl2/07/99 


04:26p 




^12/07/99 


04:26p 




7, 


:£l2/07/99 


04:26p 




14, 


!dl2/07/99 


04:26p 




34, 


^=12/07/99 


04:26p 




22, 


12/07/99 


04:26p 




22, 


12/07/99 


04:26p 




6, 


12/07/99 


04:26p 




4, 


12/07/99 


04:26p 




12, 


12/07/99 


04:26p 




4, 


12/07/99 


04:26p 




4, 


12/07/99 


04:26p 




3, 


12/07/99 


04:26p 




3, 


12/07/99 


04:26p 




6, 


12/07/99 


04:26p 




3, 


12/07/99 


04:26p 




12, 


12/07/99 


04:26p 

31 File(s) 




3, 

289 



Directory of E:\e-speak-src_991217 
fra\cci\messaging\CVS 



702 BootstrapReply . java 
492 ChannelWriter. java 
2 63 ChannelReader . java 
951 Channel. java 
280 ClientChannel . java 
CVS 

284 ESSerializable, java 
155 FIFOQueue. java 
488 InboxMessageAtom. java 
259 IVMChannel. java 
410 IVMQueue . j ava 
697 IVMRendezvous . java 
962 Makefile 
804 Message. java 
287 MessageAtom. java 
717 MessageRegistry . java 
555 MessageOutputStream. java 
914 MessagelnputStream. java 
647 MessageBuf feredStream. java 
358 MsgFilter. java 
195 OutboxMessageAtom. java 
369 PayloadReference. java 
380 PayloadFromCore . java 
4 67 PayloadForCore . j ava 
8 69 Rendezvous . java 
153 Resourceinf o. java 
800 SystemMonitorHelper . java 
380 TCPChannel. java 
22 9 TCPRendezvous. java 
,067 bytes 

\platforin\ES\src\java\net\espeak\in 
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test 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



1,538 

67 
46 
846 



Entries 

Repository- 
Root 

Template 



2,497 bytes 



f ra\cci\metadata 




fid 


. 0 op 






. s5 op 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


Q12/O7/99 


04 


: 26p 


■012/07/99 


04 


:26p 


;'^^12/06/00 


04 


: 33p 


W12/O7/99 


04 


:26p 


^5^12/07/99 


04 


:26p 


^312/07/99 


04 


:26p 


^!'l2/07/99 


04 


:26p 


^%2/07/99 


04 


:26p 


: 12/07/99 


04 


:26p 


i!:i2/07/99 


04 


:26p 


^ifl2/07/99 


04 


:26p 


:£12/07/99 


04 


:26p 


1212/07/99 


04 


:26p 


^i2/07/99 


04 


:26p 


^42/07/99 


04 


:26p 



<DIR> 
<DIR> 



<DIR> 



20 File(s) 



12,656 Attribute, java 
15,404 AttributeSet. java 

9,786 AttributePropertySet . java 
21,375 AttributeProperty . java 
10,960 AttributePredicate. java 
CVS 

29,182 ESUID.java 
704 Makefile 

1, 756 Matcherlnterf ace. java 

3,760 NamedObject . java 

1,759 Promoterlnterf ace. java 
31,730 ResourceSpecif ication. java 

6,603 ResourceDescription. java 

8,575 RSD.java 
15,618 SearchRecipe . java 

6,406 SearchPredicate. java 
20,342 ValueType. java 
59,374 Value. java 
255, 990 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ 
fra\cci\metadata\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s) 



929 
66 
46 

846 
1,887 



Entries 

Repository 

Root 

Template 
bytes 



Directory of E : \e-speak-src_991217\platf orra\ES\src\ j ava\net\espeak\ 
f ra\cci\naming 
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test 



12/06/00 


04 


: 33p 


<DIR> 


• 


12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


: 2 6p 




3,069 Accessor . java 


12/06/00 


04 


: 33p 


<DIR> 


CVS 




A A 

U4 


: zop 




27, 188 ESName. java 


12/07/99 


04 


:26p 




7,868 LiteralName . j ava 


12/07/99 


04 


:26p 




441 Makefile 


12/07/99 


04 


:26p 




7,453 NameSearchPolicy . java 


12/07/99 


04 


:26p 




4, 852 ResourceRef erence . java 






9 File(s] 




50,871 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\cci\naming\CVS 



12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/16/99 


06:19p 






^^12/16/99 


06:19p 






;Cl2/16/99 


06:19p 






.'^12/16/99 


06:19p 








6 


File (s) 


1 


Directory of E : Xe-speak-src 


991217 


|r^f ra\cci\security 






f.12/06/00 


04: 33p 


<DIR> 




1=^12/06/00 


04:33p 


<DIR> 




:il2/06/00 


04: 33p 


<DIR> 




;ril2/07/99 


04:26p 




2, 


:5l2/07/99 


04:26p 




6, 


;£l2/07/99 


04:26p 




4, 


'=•'12/07/99 


04:26p 








7 


File (s) 


13 



Directory of E:\e-speak-src_991217 
f ra\cci\security\CVS 



316 Entries 

64 Repository 

4 6 Root 
846 Template 
,272 bytes 

\platform\ES\src\java\net\espeak\in 



CVS 

228 Lockable . j ava 

335 LockedPermissions . java 

131 Lock . j ava 

394 Makefile 

,088 bytes 

\platf orm\ES\src\ java\net\espeak\in 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 203 Entries 

12/16/99 06:19p 66 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,161 bytes 



Directory of E: \e-speak-src__991217\platf orm\ES\src\ java\net\espeak\in 
f ra\client 
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test 



12/06/00 


04 


: 33p 


<DIR> 


• 


/ U b/ UU 


04 


: i3p 


<DIR> 




iz/ Ub/ Uu 


04 


: 33p 


<DIR> 


clientapi 


12/06/00 


04 


: 33p 


<DIR> 


coreproxy 


12/05/00 


04 


: 33p 


<DIR> 


corestubs 




U ft 




< U1K> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


exception 


12/06/00 


04 


: 33p 


<DIR> 


impl 


12/07/99 


04 


:26p 




301 Makefile 


12/06/00 


04 


: 33p 


<DIR> 


util 






10 File(s; 




301 bytes 



Directory of E : \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\client\clientapi 



12/06/00 

12/06/00 
J12/06/00 
S12/07/99 
^2/07/99 
n2/07/99 
fl2/07/99 
^'12/07/99 
:l2/07/99 
=^12/07/99 

12/07/99 
:i2/07/99 
fl2/07/99 
fl2/07/99 
^12/07/99 
fl2/07/99 
-12/07/99 

12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :26p 

18 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

2,613 ESContractlntf . java 

3,793 ESInboxIntf . java 

2,216 ESIntf.java 

3,218 ESKeylntf . java 

3,368 ESKeyRinglntf . java 
10,319 ESNameFramelntf . java 

3, 936 ESProtectionDoraainlntf . java 

3,788 ESRemoteObjIntf . java 
13,674 ESRLIntf . java 

3,361 ESServicelntf . java 
40,793 ESShelllntf . java 

3,018 ESSystemMonitorlntf . java 

3,339 ESViewIntf . java 

3,2 67 ESVocabularylntf . java 
674 Makefile 
101,377 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\client\clientapi\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04 : 33p 
06: 19p 
06:19p 
06:19p 
06: 19p 
6 



<DIR> 
<DIR> 



File (s) 



818 Entries 
70 Repository 
46 Root 

846 Template 
1,780 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\client\coreproxy 
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test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 33,299 ESConnectionFactory . java 

12/07/99 04:26p 7,074 ESCoreProxy . j ava 

12/07/99 04:26p 390 Makefile 

6 File(s) 40,763 bytes 

Directory of E: \e-speak:-src_991217\platform\ES\src\ java\net\espeak\in 
fra\ client \coreproxy\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 

12/16/99 06:19p 

_12/16/99 06:19p 

:S:i2/16/99 06:19p 

6 File(s) 1 



;^ Directory of E:\e-speak-src_991217 
|";f ra\client\corestubs 



;.a2/06/oo 


04:33p 


<DIR> 




!.'°l2/06/00 


04 : 33p 


<DIR> 




L12/06/00 


04:33p 


<DIR> 




i^a2/07/99 


04:26p 




12, 


;il2/07/99 


04:26p 




8, 


:il2/07/99 


04:26p 




5, 


■-.12/07/99 


04:26p 




3, 


;^12/07/99 


04 :26p 




7, 


'°i2/07/99 


04:26p 






12/07/99 


04:26p 




17, 


12/07/99 


04:26p 




6, 


12/07/99 


04:26p 




9, 


12/07/99 


04:26p 




42, 


12/07/99 


04:26p 




4, 


12/07/99 


04:26p 




3, 


12/07/99 


04:26p 




5, 


12/07/99 


04:26p 




5, 




17 File 


(s) 


133 



Directory of E:\e-speak-src_991217 
fra\client\corestubs\CVS 



162 Entries 

70 Repository 

46 Root 
846 Template 
,124 bytes 

\platform\ES\src\java\net\espeak\in 



CVS 

959 ImporterExporter . j ava 

599 Interf aceToCore , java 

527 KeyRing. java 

281 Key . java 

38 6 Mailbox. java 

642 Makefile 

94 5 NameFrame . java 

081 Protect ionDomain. java 

201 RepositoryView. java 

410 ResourceManipulat ion. java 

920 ResourceFactory . java 

4 69 ResourceContract . java 

250 SystemMonitor . java 

396 Vocabulary . java 

, 066 bytes 

\platf orm\ES\src\java\net\espeak\in 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 755 Entries 
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test 

12/16/99 06:19p 70 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,717 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\client\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 48 Entries 

12/16/99 06:19p 104 Entries. Log 

12/16/99 06:19p 60 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,104 bytes 

□ Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\in 
Mf ra\client\exception 

A^12/06/00 04:33p <DIR> 
«12/06/00 04:33p <DIR> 

^12/07/99 04:26p 2,505 CoreNotFoundException. java 

::12/06/00 04:33p <DIR> CVS 

^=12/07/99 04:26p 409 Makefile 

^12/07/99 04:26p 2,937 UnexpectedExceptionException. ja 



.ya 



6 File(s) 5,851 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
=ifra\client\exception\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 181 Ent ries 

12/16/99 06:19p 70 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1, 143 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\client\impl 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 5,506 ESContract. java 

12/07/99 04:26p 9,352 ESCoreManagementService . java 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
va 

12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04 

04 

04 

04: 

04: 

04: 
04; 
04; 
04: 
04: 
04: 
04: 
04: 
04: 
04: 
04: 
04: 



26p 
26p 
26p 
26p 
26p 

26p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
22 



File (s) 



test 

17,920 ESImporterExporter . j ava 

8,421 ESInbox.java 

7,753 ESKeyRing. java 

4,747 ESKey.java 

17,440 ESManagedCoreManagedResource 

23,204 ESN ame Frame. java 

8,391 ESProtectionDomain. java 

10,068 ESRemoteObj . java 

36,740 ESRL.java 

3,837 ESService . java 

112,191 ESShell.java 

6,037 ESSystemMonitor . java 

13,322 ESView.java 

9,7 92 ESVocabulary. java 

8,090 ES.java 

738 Makefile 

16,647 StartService. java 
320, 196 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
if ra\client\impl\CVS 



:l2/06/00 
^2/06/00 
M2/16/99 
:i2/16/99 
ii2/16/99 
ri2/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



1,011 Entries 
65 Repository 
4 6 Root 
846 Template 
1,968 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
f ra\client\util 



12/06/00 


04 


:33p 


<DIR> 








12/06/00 


04 


: 33p 


<DIR> 








12/07/99 


04 


: 26p 




10, 


093 


CoreNameList . j ava 


12/06/00 


04 


: 33p 


<DIR> 






CVS 


12/07/99 


04 


:26p 




4, 


571 


ESPOPInfo. java 


12/07/99 


04 


: 26p 




2, 


699 


ExtractException . j ava 


12/07/99 


04 


:26p 




4, 


557 


HelperMethods . java 


12/07/99 


04 


:26p 






635 


Makefile 


12/07/99 


04 


:26p 




12, 


720 


MessageState . j ava 


12/07/99 


04 


: 26p 




16, 


524 


MessageHandler . j ava 


12/07/99 


04 


: 26p 




11, 


781 


MethodPermissionMap. java 


12/07/99 


04 


:26p 




5, 


547 


MsgldentityFilter. java 


12/07/99 


04 


:26p 




5, 


919 


MsgRSDFilter. java 


12/07/99 


04 


:26p 




4, 


811 


ParameterList . j ava 
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test 

12/07/99 04:26p 5,598 ParamUnit . java 

12/07/99 04:26p 2,340 Trace . j ava 

12/07/99 04:26p 5,560 Userinf o . java 

17 Fil€(s) 93,355 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\client\util\CVS 



12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/16/99 


06: 19p 




753 Entries 


12/16/99 


06: 19p 




65 Repository 


12/16/99 


06: 19p 




4 6 Root 


12/16/99 


06: 19p 




84 6 Template 




6 


File (s) 


1,710 bytes 


^ Directory of E : Xe-speak-src 


991217\platforin\ES\s 


'=ff raXcore 






il2/06/00 


04:33p 


<DIR> 




:%2/06/00 


04:33p 


<DIR> 




112/06/00 


04: 33p 


<DIR> 


contract 


;^12/06/00 


04:33p 


<DIR> 


CVS 


:!i2/06/00 


04: 33p 


<DIR> 


exception 


■^^12/06/00 


04:33p 


<DIR> 


export 


■ .12/06/00 


04:33p 


<DIR> 


mailbox 


U2/07/99 


04 : 40p 




443 Makefile 


;Ji.2/06/oo 


04:33p 


<DIR> 


management 


:;l2/06/00 


04:33p 


<DIR> 


naming 


!a.2/06/00 


04:33p 


<DIR> 


pd 


;=i2/06/00 


04:33p 


<DIR> 


plugins 


■■"12/06/00 


04:33p 


<DIR> 


quota 


12/06/00 


04:33p 


<DIR> 


repository 


12/06/00 


04:33p 


<DIR> 


resource 


12/06/00 


04:33p 


<DIR> 


router 


12/06/00 


04:33p 


<DIR> 


security 


12/06/00 


04:33p 


<DIR> 


startup 


12/06/00 


04:33p 


<DIR> 


sysmon 


12/06/00 


04:33p 


<DIR> 


util 


12/06/00 


04:33p 


<DIR> 


vocabulary 




21 


File (s) 


443 bytes 



Directory of E: \e-speak-src_991217\platforni\ES\src\java\net\espeak\in 
f ra\core\contract 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:40p 12,648 Contract . java 
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test 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 375 Makefile 

12/07/99 04:40p 2,666 RegistrylF. java 

6 File(s) 15,689 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\core\contract\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 150 Entries 

12/16/99 06:19p 67 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,109 bytes 

^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
^fra\core\CVS 

^12/06/00 04:33p <DIR> 
^=;i2/06/00 04:33p <DIR> 

^12/16/99 06:19p 48 Entries 

fl2/16/99 06:20p 289 Entries. Log 

::i2/16/99 06:19p 58 Repository 

^^12/16/99 06:19p 46 Root 

^2/16/99 06:19p 846 Template 

II 7 File(s) 1,287 bytes 

; Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
^:f ra\core\exception 

=^12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:40p 2,531 AssertionFailedException . j ava 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 372 Makefile 

5 File (s) 2, 903 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\core\exception\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 114 Entries 

12/16/99 06:19p 68 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,074 bytes 
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test 



Directory of E: \e-speak-src_991217\platf orin\ES\src\ j ava\net\espeak\in 
f ra\core\export 



12/06/00 


04: 


33p 


<DIR> 






12/06/00 


04: 


33p 


<DIR> 






12/06/00 


04: 


33p 


<DIR> 




CVS 


12/07/99 


04: 


40p 




5, 999 


ExportMessagelnputStream 


12/07/99 


04: 


40p 




42,803 


Exporter . java 


12/07/99 


04: 


40p 




8, 112 


FrameMapEnt ry . j ava 


12/07/99 


04: 


40p 




19, 363 


ImportExportNaities . java 


12/07/99 


04: 


40p 




26,949 


ImporterExporter . j ava 


12/07/99 


04: 


40p 




55,249 


Importer . java 


12/07/99 


04: 


40p 




485 


Makefile 



10 File(s) 



158,960 bytes 



_ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
ff ra\core\export\CVS 



.'^^2/06/00 


04: 


33p 


:^12/06/00 


04: 


33p 


^2/16/99 


06: 


19p 


1-^12/16/99 


06: 


19p 


:::i2/i6/99 


06: 


19p 


^^2/16/99 


06: 


19p 
6 


[Z, Directory of 


E: 


■=j;f ra\core\mailbox 


:S:i2/o6/oo 


04: 


33p 


^''12/06/00 


04: 


33p 


12/07/99 


04: 


40p 


12/07/99 


04: 


40p 


12/07/99 


04: 


40p 


12/07/99 


04: 


4 Op 


12/06/00 


04: 


33p 


12/07/99 


04: 


40p 


12/07/99 


04: 


40p 


12/07/99 


04: 


40p 


12/07/99 


04: 


40p 


12/07/99 


04: 


40p 



<DIR> 
<DIR> 



File (s: 



386 Entries 
65 Repository 
4 6 Root 

846 Template 
1, 343 bytes 



<DIR> 
<DIR> 



<DIR> 



12 File(s; 



6,974 ChannelWriterThread. java 
2, 655 ChannelWriterDaemon . j ava 
6,985 ChannelThreadPool. java 
4,675 CoreChannel . java 
CVS 

10,995 Inbox. java 
527 Makefile 
2,344 MessageQueueltem. java 
5,321 MessageQueue. java 

10,818 Outbox.java 
51,294 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\mailbox\CVS 



12/06/00 04:33p 



<DIR> 
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test 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 489 Entries 

12/16/99 06:19p 66 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,447 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\management 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 372 Makefile 

12/07/99 04:40p 16,612 ManagedAbstractRe source. java 

5 File(s) 16,984 bytes 

J Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
ra\core\inanagement \CVS 

^%2/06/00 04:33p <DIR> 

■M2/06/00 04:33p <DIR> 

;'=^12/16/99 06:19p 113 Entries 

:rl2/16/99 06:19p 69 Repository 

^^=12/16/99 06:19p 46 Root 

;U2/16/99 06:19p 846 Template 

6 File{s) 1, 074 bytes 

:rf Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
"ff ra\core\naming 



5,107 Binding. java 
CVS 

454 Makefile 
23,229 MappingObject . java 
94,368 NameFrame . java 
8,209 NameSearchPolicyMatcher . java 
6,580 PartialBinding. java 
9 File(s) 137,947 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\naming\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 324 Entries 



-12/06/00 


04: 


33p 


<DIR> 


12/06/00 


04 : 


33p 


<DIR> 


12/07/99 


04: 


40p 




12/06/00 


04: 


33p 


<DIR> 


12/07/99 


04: 


40p 




12/07/99 


04: 


4 Op 




12/07/99 


04: 


40p 




12/07/99 


04: 


40p 




12/07/99 


04: 


4 Op 
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12/16/99 
12/16/99 
12/16/99 



06: 19p 
06: 19p 
06: 19p 
6 



File (s) 



test 

65 Repository 
4 6 Root 
846 Template 
1,281 bytes 



Directory of E: \e-speak-src_991217\platforin\ES\src\java\net\espeak\in 
f ra\core\pd 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04: 40p 
04:40p 
04:40p 
6 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

377 Makefile 
30,042 Protect ionDomain. java 
5,997 WorkingSet , java 
36,415 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
ff ra\core\pd\CVS 



^2/06/00 
112/06/00 
fl2/16/99 
fl2/16/99 
12/16/99 
=12/16/99 



04:33p 
04:33p 
06: 19p 
06: 19p 
06: 19p 
06: 19p 
6 



<DIR> 
<DIR> 



File (s) 



158 Entries 
61 Repository 
4 6 Root 

846 Template 
1,111 bytes 



t Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
=f ra\core\plugins 



a2/06/00 
=12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/06/00 



04:33p 
04 :33p 
04:33p 
04:40p 
04:40p 
04 : 40p 
04: 40p 
04:33p 
04: 33p 



<DIR> 
<DIR> 
<DIR> 



<DIR> 
<DIR> 



9 File(s] 



CVS 

393 Makefile 
3,4 95 PluglnLoader . java 
1,776 PluglnlF. java 
4,548 Plugln.java 
secureboot 
testplugin 
10,212 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\plugins\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:19p 

12/16/99 06:19p 



<DIR> 
<DIR> 



200 Entries 
40 Entries. Log 
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test 

12/16/99 06:19p 66 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,198 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\plugins\secureboot 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 4,395 SecureBoot . java 

4 File(s) 4,395 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
fra\core\plugins\secureboot\CVS 

3l2/06/00 04:33p <DIR> 
312/06/00 04:33p <DIR> 

112/16/99 06:19p 55 Entries 

112/16/99 06:19p 77 Repository 

rl2/16/99 06:19p 46 Root 

fl2/16/99 06:19p 846 Template 

6 File(s) 1, 024 bytes 

^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
"jf ra\core\plugins\testplugin 

^12/06/00 04:33p <DIR> 
=12/06/00 04:33p <DIR> 

r:i2/06/00 04:33p <DIR> CVS 

=12/07/99 04:41p 1,915 TestPlugln. java 

4 File (s) 1, 915 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\core\plugins\testplugin\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 55 Entries 

12/16/99 06:19p 77 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,024 bytes 

Directory of E : \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\core\quota 
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12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:41p 




12/07/99 


04 


:41p 




12/07/99 


04 


:41p 




12/07/99 


04 


:41p 








7 


File (s) 



test 



CVS 

389 Makefile 
10,189 QuotaCheck. java 
14,951 QuotaSize . java 
25,082 Quota. java 
50,611 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\quota\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
112/16/99 



04: 
04; 
06: 
06: 
06: 



33p 
33p 
19p 
19p 
19p 



<DIR> 
<DIR> 



06:19p 

6 



File (s) 



198 Entries 
64 Repository 
4 6 Root 

846 Template 
1,154 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
=^f ra\core\repository 



^^12/06/00 


04:33p 


<DIR> 


™12/06/00 


04:33p 


<DIR> 


12/07/99 


04:41p 




^^12/07/99 


04:41p 




^.yi2/07/99 


04:41p 




^12/07/99 


04:41p 




■ffl2/07/99 


04:41p 




yi2/06/00 


04:33p 


<DIR> 


^=^12/07/99 


04:41p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04: 41p 




12/05/00 


04:33p 


<DIR> 


12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04: 41p 






20 File 


(s) 



14,917 AbstractStore. java 

7,254 ActiveResourceOwners . java 
14,950 CacheEntry . java 
10,740 CacheStats. java 
30,996 Cache. java 
CVS 

15,7 03 DumpCore .java 
jdbc 
771 Makefile 
mem 

17,870 RepositoryView. java 

4,437 RepositoryReset .java 
24,681 RepositoryHandle. java 
30,2 83 Repository. java 
29,593 Scavenger . java 
3,452 StoreUnitsIF. java 
8,091 StoreUnitList. java 
4,335 StoreUnit. java 
218,083 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\core\repository\CVS 
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test 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 800 Entries 

12/16/99 06:20p 27 Entries. Log 

12/16/99 06:19p 69 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,788 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\repository\jdbc 

<DIR> 
<DIR> 

<DIR> CVS 

14,197 JDBCRepositoryHandle. java 
29,056 JDBCHouseKeeping. java 
31,040 JDBCResourceState. java 
13, 912 JDBCResourceSpecif ication. java 
10,243 JDBCResourceLookup. java 
22, 361 JDBCResourceDescription. java 
17,317 JDBCSqlSt rings. java 
16,847 JDBCStore. java 
576 Makefile 
12 File(s) 155,549 bytes 

] Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
^f ra\core\repository\ j dbc\CVS 

il2/06/00 04:33p <DIR> 

U2/06/00 04:33p <DIR> 

'12/16/99 06:20p 526 Entries 

12/16/99 06:19p 74 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File (s) 1, 492 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\core\repository\mein 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 Q4:33p <DIR> CVS 

12/07/99 04:41p 381 Makefile 

12/07/99 04:41p 7,591 MemStoreDB . j ava 

12/07/99 04:41p 14,777 MemStore. java 

6 File(s) 22,749 bytes 



12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:41p 


12/07/99 


04 


:41p 


O12/07/99 


04 


:41p 


:*n2/07/99 


04 


:41p 


,112/07/99 


04 


:41p 


1^12/01/99 


04 


:41p 


;ifl2/07/99 


04 


:41p 


:==fl2/07/99 


04 


:41p 


:^12/07/99 


04 


:41p 
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test 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\core\repository\mem\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 150 Entries 

12/16/99 06:20p 73 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,115 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\re source 



12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/07/99 


04:41p 




18,587 


^=12/07/99 


04:41p 




23,240 


#2/06/00 


04:33p 


<DIR> 


^"42/07/99 


04:41p 




15,970 


^4.2/07/99 


04:41p 




6,218 


^ii.2/07/99 


04 :41p 




576 


142/07/99 


04 : 41p 




59, 946 


tt2/07/99 


04:41p 




2,800 


^12/07/99 


04:41p 




14,087 


f 12/07/99 


04:41p 




12,611 


:l2/07/99 


04:41p 




17,749 




13 


File (s) 


171,78 



AbstractResource . j ava 
CoreManagementService , j ava 
CVS 

ESUIDFactory. java 
ExternalResource , j ava 
Makefile 

MetaResource . j ava 
MutableResourcelF. java 
ResourceType . j ava 
ResourceSpecif ication, java 
ResourceFactory . java 
I bytes 

if Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
Sf ra\core\resource\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 568 Entries 

12/16/99 06:20p 67 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,527 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\core\r outer 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:41p 




369 


Makefile 


12/07/99 


04 


:41p 




2,282 


Response 
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test 

12/07/99 04:41p 17,060 Router. Java 

6 File(s) 19,711 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\router\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 146 Entries 

12/16/99 06:20p 65 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,103 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\ security 



CVS 

1,824 KeylF.java 
10,631 KeyRing.java 
7,550 Key.java 
456 Makefile 
24,731 MDS.java 
9,913 SecurityContextFactory . j ava 
3,095 SecurityContext . java 
58,200 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
Sf ra\core\security\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 355 Entries 

12/16/99 06:20p 67 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,314 bytes 

Directory of E:\e-speak-src_991217\platforra\ES\src\java\net\espeak\in 
fra\core\ startup 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:41p 12,653 CoreArgs . java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:41p 414 Makefile 



^12/06/00 


04: 


33p 


<DIR> 


;Ol2/06/00 


04: 


33p 


<DIR> 


.'==^12/06/00 


04: 


33p 


<DIR> 


^^12/07/99 


04: 


41p 




■^2/07/99 


04: 


41p 




:'=^12/07/99 


04: 


41p 




i!:;i2/07/99 


04: 


41p 




^^12/07/99 


04: 


41p 




:\12/07/99 


04 : 


41p 




i!:i2/07/99 


04: 


41p 








10 


File (s) 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:41p 
04:41p 
04:41p 
04:41p 

9 File(s) 



test 

2,166 pingServer . real 
5,724 Server. java 
6,003 StartESCore. java 
35,876 StartupCore. java 
62,836 bytes 



Directory of E:\e-speak-src_991217\platforni\ES\src\java\net\espeak\in 
f ra\core\startup\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



304 Entries 
66 Repository 
46 Root 

84 6 Template 
1,262 bytes 



I Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
!f ra\core\sysraon 



a2/06/00 
fl2/05/00 
^12/06/00 
'12/07/99 
'12/07/99 



04:33p 
04:33p 
04:33p 
04:41p 
04:41p 
5 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

357 Makefile 
8,817 SystemMonitor. java 
9,174 bytes 



i Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
^f ra\core\sysinon\CVS 



:i2/06/00 


04:33p 


<DIR> 




12/06/00 


04: 33p 


<DIR> 




12/16/99 


06:20p 




103 Entries 


12/16/99 


06:20p 




65 Repository 


12/16/99 


06:20p 




4 6 Root 


12/16/99 


06:20p 




846 Template 




6 


File (s) 


1, 060 bytes 


Directory of E:\e-speak-src 


991217\platform\ES\src\java\net\espeak\in 


f ra\core\util 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/07/99 


04:41p 




24,650 CoreHelper . java 


12/06/00 


04:33p 


<DIR> 


CVS 


12/07/99 


04:41p 




35,4 64 Logger. java 


12/07/99 


04:41p 




395 Makefile 


12/07/99 


04:41p 




7,453 ServiceRegistry . java 
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7 File(s) 



test 

67,972 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\util\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 205 Entries 

12/16/99 06:20p 63 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,160 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\ vocabulary 

.12/06/00 04:33p <DIR> 
312/06/00 04:33p <DIR> 

012/06/00 04:33p <DIR> CVS 

112/07/99 04:41p 24,331 Expression. java 

yi2/07/99 04:41p 3,717 ExprNode . java 

5:12/07/99 04:41p 9, 836 LiteralNode . java 

fl2/07/99 04:41p 480 Makefile 

"12/07/99 04:41p 19,310 OpNode.java 

«12/07/99 04:41p 5,454 PropertyNode . java 

.^2/07/99 04:41p 17,130 Tokenizer . java 

.J2/07/99 04:41p 16,969 Vocabulary . java 

3 11 File(s) 97,227 bytes 

^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 

,:;fra\core\ vocabulary \CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 408 Entries 

12/16/99 06:20p 69 Repository 

12/16/99 06:20p 46 Root 

12/15/99 06:20p 846 Template 

6 File(s) 1,369 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 48 Entries 

12/16/99 06:20p 78 Entries. Log 

12/16/99 06:19p 53 Repository 
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12/16/99 06:19p 
12/16/99 06:19p 

7 File(s: 



test 

4 6 Root 
846 Template 
1,071 bytes 



f ra\intercorecoiti 






12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 


conf actory 


12/06/00 


04:33p 


<DIR> 


connectors 


12/06/00 


04:33p 


<DIR> 


CVS 


12/06/00 


04:33p 


<DIR> 


esip 


12/07/99 


04:26p 




303 Makefile 


12/06/00 


04:33p 


<DIR> 


proxy 


12/06/00 


04:33p 


<DIR> 


stacks 


„.12/06/00 


04:33p 


<DIR> 


util 




10 


File (s) 


303 bytes 



\ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
;fra\intercorecom\conf actory 



7,252 CFEventPublisher.java 
6,288 CFStatistics. java 

CO 

2, 138 CornmunicationManagerException. j 

65,4 37 CommunicationManager . java 
7, 656 ConnectionRegistry . java 
3,571 ConnectionEntry . java 
3,309 ConnFactoryTags . java 
6,409 ConnFactorySM. java 
4,682 ConnFactoryInf o . java 
2,133 Cr eat eProxyExcept ion, java 
CVS 

502 Makefile 
policy 
3, 523 StatsUpdate. java 
113, 000 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\intercorecom\conf actory \co 



:==l2/06/00 


04: 33p 


<DIR> 


:r!l2/06/00 


04:33p 


<DIR> 


■-12/07/99 


04:26p 




f .12/07/99 


04:26p 




;r:i2/o6/oo 


04:33p 


<DIR> 


^12/07/99 


04:26p 




'°-ava 






:Sl2/07/99 


04:26p 




;Sl2/07/99 


04:26p 




'^'12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 






17 


File (s) 



12/06/00 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 



<DIR> 
<DIR> 



6,484 ConnectionObject . java 
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test 

12/07/99 04:26p 2,892 Connect ioninf ointf . j ava 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 2,515 SerializationException. java 

12/07/99 04:26p 5,225 TCPConnectionlnfo. java 

7 File(s) 17,116 bytes 

Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\in 
fra\intercorecom\conf actory\co\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 244 Entries 

12/16/99 06:20p 80 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,216 bytes 

□ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
Mf ra\intercorecom\conf actory\CVS 

A42/06/00 04:33p <DIR> 

f^l2/06/00 04:33p <DIR> 

312/16/99 06:20p 694 Entries 

fl2/16/99 06:20p 28 Entries. Log 

^12/16/99 06:20p 77 Repository 

\12/16/99 06:20p 46 Root 

f:i2/16/99 06:20p 846 Template 

jf 7 File (s) 1, 691 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
^=Jf ra\intercorecom\conf actoryXpolicy 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 13,446 Negotiator . j ava 

12/07/99 04:26p 14,105 NegotiationPolicy . java 

12/07/99 04:26p 4,684 NegotiationOf fer. java 

12/07/99 04:26p 2,348 NegotiationFailedException . j ava 

12/07/99 04:26p 3,337 SecurityPolicy . j ava 

8 File(s) 37,920 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\intercorecom\confactory\policy\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 296 Ent ries 
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12/16/99 
12/16/99 
12/16/99 



06:20p 
06:20p 
06:20p 

6 File(s; 



test 

84 Repository 
46 Root 
846 Template 
1,272 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\intercorecom\connectors 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
il2/07/99 
il2/07/99 
il2/07/99 



04: 33p 
04:33p 
04:26p 
04:26p 



04 
04 
04 
04 
04 



26p 
33p 
26p 
26p 
26p 



<DIR> 
<DIR> 



<DIR> 



04:26p 
04:26p 
04:26p 
12 



File(s) 



7,732 ConnectorManager . java 
6,183 ConnectorDesc. java 
4,495 Connector . java 
CVS 

5,514 DataConnector . java 
3,714 ListeningConnector . java 
557 Makefile 
13,703 TcpDataConnector . java 
7,334 TcpListeningConnector . java 
6,420 TcpTunnelConnector . java 
55,652 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
'fra\intercorecom\ connect orsXCVS 



12/06/00 
:l2/06/00 
^12/16/99 
fl2/16/99 
fl2/16/99 
fl2/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



508 Entries 
77 Repository 
4 6 Root 

846 Template 
1,477 bytes 



Directory of E : \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
fra\intercorecom\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
05:20p 
06:20p 
06: 20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File (s) 



48 Entries 
99 Entries. Log 
66 Repository 
46 Root 
846 Template 
1,105 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\intercorecom\esip 
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12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/06/00 


04 


:33p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/08/99 


03 


:16p 



test 

<DIR> 
<DIR> 

<DIR> CVS 

3,548 ESIPControlMessage. java 
5,727 ESIPExportMessage. java 
4,267 ESIPHeader. java 
4,123 ESIPMessage. java 
2,126 ESIPPayload. java 
461 Makefile 
9 File(s) 20,252 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\intercorecom\esip\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 325 Entries 

^2/16/99 06:20p 71 Repository 

='12/16/99 06:20p 46 Root 

jl2/16/99 06:20p 846 Template 

\ 6 File{s) 1,288 bytes 

J Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
;f ra\ inter corecomXproxy 



CVS 

2, 166 EbyteArrayOutputStream. java 
533 Makefile 
12,689 ProxyAPIHandler. java 
27,950 ProxyExportHandler . java 

8,861 ProxyHelper . java 

9,709 ProxylmportHandler . java 
36,159 Proxy. java 
26,195 StateMgr . java 

3,8 82 Timeouts . java 
128,144 bytes 



' 12/06/00 


04:33p 


<DIR> 


■:'l2/06/00 


04:33p 


<DIR> 


^ifl2/06/00 


04:33p 


<DIR> 


■;:fl2/07/99 


04:26p 




:^12/07/99 


04:26p 




^12/07/99 


04:26p 




^=^12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 






12 


File (s) 


Directory of E:\e-speak-src 


f ra\intercorecom\proxy\CVS 


12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/16/99 


06:20p 




12/16/99 


06:20p 




12/16/99 


06:20p 




12/16/99 


06:20p 





489 Entries 

72 Repository 

4 6 Root 

84 6 Template 



Page 64 



6 File(s) 



test 
1,453 bytes 



fra\intercorecom\ stacks 






12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/07/99 


04:26p 




5,443 


12/06/00 


04:33p 


<DIR> 




12/07/99 


04:26p 




457 


12/07/99 


04:26p 




4, 429 


12/07/99 


04:26p 




14,775 



CVS 



layers 



8 File(s) 



25,104 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\intercorecom\stacks\CVS 



^12/06/00 
^2/06/00 
^12/16/99 
^12/16/99 
^12/16/99 
:i2/16/99 
^12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File (s) 



203 Entries 
16 Entries. Log 
73 Repository 
46 Root 

846 Template 
1,184 bytes 



; Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
;fra\intercorecom\ stacks Mayers 



^=:12/06/00 


04 


:33p <DIR> 




^=12/06/00 


04 


:33p <DIR> 




12/07/99 


04 


:26p 


2,166 CILayer.java 


12/06/00 


04 


:33p <DIR> 


CVS 


12/07/99 


04 


:26p 


3,461 Layerlntf . java 


12/07/99 


04 


:26p 


4,834 Layer. java 


12/07/99 


04 


:26p 


464 Makefile 


12/07/99 


04 


: 26p 


7,071 NameAuthenticationLayer 


12/07/99 


04 


:26p 


2,221 TransportLayer . java 






9 File (8) 


20,217 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\intercorecom\stacks Mayers \CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:20p 

12/16/99 06:20p 



<DIR> 
<DIR> 



316 Entries 
80 Repository 
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test 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

5 File(s) 1,288 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\intercorecoin\util 



12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/07/99 


04:26p 




3,820 


12/07/99 


04:26p 




7,348 


12/06/00 


04:33p 


<DIR> 




12/07/99 


04:26p 




4,748 


12/07/99 


04:26p 




3,180 


12/07/99 


04:26p 




439 


12/07/99 


04:26p 




3,276 


12/07/99 


04:26p 




3,090 



CondVar . j ava 

ConnectionOb" 

CVS 



. java 



10 File(s) 25,901 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
:=^:f ra\intercorecom\util\CVS 

^12/06/00 04:33p <DIR> 

:r:i2/06/00 04:33p <DIR> 

■^2/16/99 06:20p 367 Entries 

12/16/99 06:20p 71 Repository 

:^12/16/99 05:20p 46 Root 

;=^12/16/99 06:20p 846 Template 

■ i 6 File (s) 1, 330 bytes 

i Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
""f ra\xml 



12/06/00 


04 


:33p 


<DIR> 








12/06/00 


04 


:33p 


<DIR> 








12/06/00 


04 


: 33p 


<DIR> 






CVS 


12/07/99 


04 


:26p 




2, 


931 


ESXMLDecoderlntf . j ava 


12/07/99 


04 


: 26p 




49, 


369 


ESXMLDecoder . j ava 


12/07/99 


04 


:26p 






453 


ESXMLEncoderInt f . j ava 


12/07/99 


04 


: 26p 




6, 


183 


ESXMLEncoder . j ava 


12/07/99 


04 


:26p 




2, 


761 


ESXMLShelllntf . j ava 


12/07/99 


04 


:26p 




20, 


001 


ESXMLShell. java 


12/06/00 


04 


:33p 


<DIR> 






IE5 


12/07/99 


04 


:26p 






515 


Makefile 


12/06/00 


04 


: 33p 


<DIR> 






schema s 


12/07/99 


04 


: 26p 




7, 


355 


XMLApp . j ava 


12/07/99 


04 


:26p 




4, 


425 


XMLNameList . j ava 


12/06/00 


04 


:33p 


<DIR> 






xmlserver 
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15 File(s) 



test 

95,993 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\xml\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 481 Entries 

12/16/99 06:20p 49 Entries. Log 

12/16/99 06:20p 57 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

7 File(s) 1,479 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\xml\IE5 



□12/06/00 


04:33p 


<DIR> 




012/06/00 


04:33p 


<DIR> 




^12/06/00 


04:33p 


<DIR> 




=912/07/99 


04:26p 






f^jl2/07/99 


04:26p 




1, 


312/07/99 


04:26p 




3, 


:^12/07/99 


04:26p 




"^12/07/99 


04:26p 




1, 


' 12/07/99 


04:26p 




3, 


:^12/07/99 


04:26p 




3, 


]fl2/07/99 


04:26p 




Ir 


5i2/07/99 


04:26p 




3, 




12 


File (s) 


20 



^ Directory of E:\e-speak-src_991217 
fra\xml\IE5\CVS 



CVS 

854 e-speak_logo.gif 
7 92 lookup. htm 
320 lookup. js 
628 Readme.txt 
623 register.htm 
226 register. js 
631 response. js 
757 vocab.htm 
873 vocab.js 
,704 bytes 

\platform\ES\src\java\net\espeak\in 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 432 Entries 

12/16/99 06:20p 61 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,385 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\xml\schemas 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 
04:26p 



8 File{s) 



test 

4,405 es-basic. xsd 

368 es-lookup . xsd 

419 es-register . xsd 

589 es-response . xsd 

498 es-vocab.xsd 
6,279 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\xml\schemas\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



255 Entries 
65 Repository 
4 6 Root 
846 Template 
1,212 bytes 



J Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
sf ra\xinl\xinlserver 



^12/06/00 


04 


: 33p 


012/06/00 


04 


: 33p 


^=^12/06/00 


04 


:33p 


^12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


^112/07/99 


04 


:26p 


^^2/07/99 


04 


: 26p 


^fi2/07/99 


04 


:26p 



<DIR> 
<DIR> 
<DIR> 



8 File(s; 



CVS 

5,291 ESXMLHttp. java 

3,218 ESXMLServerThread. java 

3,397 ESXMLServer. java 

314 Makefile 
8,305 TestServerApp. java 
20,525 bytes 



- Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\xml\xml server \CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:20p 

12/16/99 06:20p 

12/16/99 06:20p 

12/16/99 06:20p 

6 File(s) 



<DIR> 
<DIR> 



266 Entries 
67 Repository 
4 6 Root 

84 6 Template 
1,225 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\je 
si 



12/06/00 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 



<DIR> 
<DIR> 



7,741 AppSessionlDFilter . java 
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12/07/99 


04 


:26p 


12/07/99 


04 


:2 6p 


12/06/00 


04 


: 33p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


P12/07/99 


04 


:26p 


^Ol2/07/99 


04 


:26p 


^12/07/99 


04 


:26p 


^=^^12/07/99 


04 


:26p 


W12/07/99 


04 


:26p 


312/07/99 


04 


: 26p 


!':l2/07/99 


04 


: 26p 


^"^^12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


1^12/07/99 


04 


:26p 


^Jfl2/07/99 


04 


: 2 6p 


:^jl2/07/99 


04 


. 26p 


^12/07/99 


04 


.26p 


^12/07/99 


04' 


26p 


^=^12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04 : 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


TO / r\'~! / r\ r\ 

12/07/99 


04 : 


26p 


12/07/99 


04 : 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 



test 

9,404 ClassDependencyFinder . java 
9,098 ClassFinder. java 
CVS 

3,496 ESContract. java 
55,605 ESAbstract Finder. java 
38,691 ESAbstractElement . java 

8,783 ESAccessRight. java 
47,370 ESAccessorStub. java 

2,293 ESAccessorHandle. java 
17, 372 ESAccessor , java 

4,455 ESAppSessionlD. java 

3,690 ESAssert. java 

9,610 ESAttribute. java 
17,621 ESBaseServiceStub. java 

2,226 ESBaseService . java 

9,288 ESBaseQuery. java 
22,360 ESBaseDescription. java 

7,475 ESServiceDescription. java 

5,151 ESVocabularyElement . java 

2,374 ESService. java 

4,939 ESCallbacklntf . java 

7,132 ESCallbacklmpl. java 

2,478 ESCloneable. java 
12, 0 68 ESCommunity . j ava 
11,751 ESConf iguration. java 
18,190 ESConnector. java 
47,841 ESConnect ion. java 

6,580 ESConstants. java 

8,475 ESContractStub. java 

6,541 ESContract Finder. java 

7,47 4 ESContractElement, java 

7,914 ESContractDescription. java 
44,996 ESServiceElement. java 
12,517 ESServiceContext . java 

6,168 ESFolderFinder. java 
55,878 ESFolder. java 

3,806 ESHashMap. java 

5,331 ESHelper. java 

5,2 95 ES Impl Proxy . java 

2,228 ESIntrospectionlntf . java 

5,026 ESIntrospectionlmpl. java 

9,790 ESList.java 

1,97 7 ESManagementlntf . java 

2,633 ESMessageRegistrylntf . java 

4, 917 ESMessage. java 
14, 917 ESMPM. java 

2,388 ESNameFactory, java 

3,755 ESQuery . java 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
112/07/99 
112/07/99 
112/07/99 
112/07/99 
^12/06/00 
^12/07/99 
'12/07/99 
^12/06/00 



04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:33p 
76 



<DIR> 



<DIR> 



File (s; 



test 

3,189 ESRunnable. java 
13,633 ESScope.java 

2,564 ESSecuritylntf . java 

8,649 ESServiceStub. java 
18,986 ESServiceMessenger. java 
21,090 ESServiceHandler. java 

8,170 ESServiceFinder. java 

2,507 ESSessionlntf . java 

4,693 ESSessionlmpl . java 
18,154 ESStartService. java 

2,223 ESStubFactorylntf . java 

6.867 ESStubFactorylmpl. java 
4,213 ESThread. java 

4,909 ESUniqList. java 
6,042 ESUserCredential. java 
20, 618 ESVocabularyDescription. java 

2.868 ESVocabulary . java 

8, 682 ESVocabularyStub . j ava 
6,647 ESVocabularyFinder. java 
3,243 ESXMLFile. java 
5,276 ESXMLQuery. java 
event 

5,290 GenericClassLoader . java 
2,169 Makefile 

management 
788,790 bytes 



f Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\i 

fsi\CVS 



?fl2/06/00 
=^12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04: 33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File (s) 



3,944 Entries 

35 Entries. Log 
52 Repository 
46 Root 
84 6 Template 
4, 923 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\j 
si\event 



12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:33p 
04:26p 
04:26p 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



coredist 
CVS 

15,259 ESCoreSubscriber . java 
2,359 ESCoreListenerlntf . java 
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12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/06/00 


04 


:33p 


12/06/00 


04 


:33p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/06/00 


04 


: 33p 






21 



<DIR> 
<DIR> 



<DIR> 



File (s) 



test 

14,426 ESDistributor . java 
6,481 ESListenerStub. java 
2,777 ESListenerlntf , java 
5,660 ESPublisherStub. java 
2,589 ESPublisherlntf . java 
20,502 ESPublisher. java 
17,999 ESSubscriber. java 
2,059 EventException. java 
impl 
intf 
730 Makefile 
5,740 Publisherlnfo. java 
4,843 ResultSetEntry. java 
5,769 ResultSet. java 
util 
107,193 bytes 



I Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\je 
^si\event\coredist 



^«12/06/00 


04 


: 33p 


<DIR> 


^12/06/00 


04 


: 33p 


<DIR> 


^12/07/99 


04 


:26p 




^^12/06/00 


04 


: 33p 


<DIR> 


^^12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




lr:i2/07/99 


04 


:26p 




^}^12/07/99 


04 


:26p 




^12/07/99 


04 


:26p 








9 


File (s) 



6,908 CoreSubProf ile. java 
CVS 

3,621 ESCoreListenerStub. java 
4,352 ESCoreDistributorStub. java 
3,343 ESCoreDistributorlntf . java 
8,886 ESCoreDistributor Impl. java 

485 Makefile 
27,595 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\je 
si\event\coredist \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s: 



353 Entries 
67 Repository 
46 Root 

846 Template 
1,312 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\je 
si\event\CVS 



12/06/00 
12/06/00 
12/16/99 



04:33p 
04:33p 
06:20p 



<DIR> 
<DIR> 



772 Entries 
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12/16/99 
12/16/99 
12/16/99 
12/16/99 



06:20p 
06:20p 
06:20p 
06:20p 
7 



File(s: 



test 

60 Entries. Log 
58 Repository 
46 Root 
846 Template 
1,782 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\je 
si\event\impl 



12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


ava 






12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


^□12/07/99 


04 


:26p 


fll2/07/99 


04 


:26p 


'=412/07/99 


04 


:26p 



<DIR> 
<DIR> 
<DIR> 



10 File{s) 



CVS 

11,967 DistributorStore. java 

10, 316 ESEventServiceComponentHelper. j 

17,224 ESEventServiceComponent . java 
12, 805 ESEventDistributorlmpl. java 
510 Makefile 

5,724 RegisterEventABI . java 

4,909 SubsDet.java 

63, 455 bytes 



i Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ie 
=s i \event \ impl \CVS 



12/06/00 
:^12/06/00 
yi2/16/99 
ffl2/16/99 
%2/16/99 
i2/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



413 Entries 
63 Repository 
4 6 Root 
84 6 Template 
1,368 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\je 
si\event\intf 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


:26p 




10,752 


12/07/99 


04 


:26p 




3,317 


y . java 










12/07/99 


04 


:26p 




4,324 


12/07/99 


04 


:26p 




11,792 


12/07/99 


04 


:26p 




3,320 


ry . java 










12/07/99 


04 


: 26p 




2, 865 


12/07/99 


04 


:26p 




4,945 



CVS 
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test 



ava 

12/07/99 04:26p 
java 

12/07/99 04:26p 

12 File(s) 



3, 346 ESPublisherlntfMessageRegistry 

613 Makefile 
45,274 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\ j 
si\event\intf \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



578 Entries 
63 Repository 
4 6 Root 

84 6 Template 
1,533 bytes 



I Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\j 
tsi\event\util 



112/06/00 
^12/06/00 
^12/07/99 
12/06/00 
12/07/99 
' 12/07/99 
:';i2/07/99 
lfl2/07/99 
iL2/07/99 
S12/O7/99 
£12/07/99 
=12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 



04 
04 
04 
04 



;26p 
; 33p 
;26p 
;26p 



<DIR> 
<DIR> 

<DIR> 



04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
14 



File(s) 



4,686 CoreEvent Predicate. java 
CVS 

5,530 EventContext . java 
3,783 EventDataTypes. java 
8,788 EventMapEntry. java 
8,550 EventMap . j ava 
8,253 Event Predicate. java 
5,526 Id. java 
6,323 Inputlnfo. java 

551 Makefile 
6,391 PubProfile. java 
9,576 SubProfile. java 
67, 957 bytes 



Directory of E : \e-speak-src_991217\platform\ES\src\java\net\espeak\i< 
si\event\util\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File(s) 



578 Entries 
63 Repository 
4 6 Root 

846 Template 
1,533 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\j 
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si\management 



test 



12/06/00 


04 : 33p 


<DIR> 




12/06/00 


04 : 33p 


<DIR> 




12/07/99 


04 : 26p 




12,092 




U4 : 2dp 




2,703 


12/06/00 


04 : 33p 


<DIR> 




12/07/99 


04 : 26p 




2, 672 


12/07/99 


04 : 26p 




2,415 


12/07/99 


04 : 26p 




1, 135 


12/07/99 


04 : 26p 




12,899 


12/07/99 


04 : 26p 




15,798 


12/07/99 


04:26p 




2,306 


ry . java 








12/07/99 


04 : 26p 




12,899 


12/07/99 


04:26p 




3,496 


12/07/99 


04 :26p 




2, 680 


4fl2/07/99 


04:2 6p 




2,395 


;fe;12/07/99 


04 : 26p 




1,748 


-=iz/u // yy 


04 : 2 bp 




2, 800 


W12/07/99 


04:26p 




6,580 


W12/07/99 


04:26p 




6,096 


O12/O7/99 


04:26p 




1,770 


^:^12/07/99 


04:26p 




3,097 


^%2/07/99 


04:26p 




1, 965 


:■ 12/07/99 


04:26p 




2,734 




23 File(s) 




100,280 



CVS 



5: Directory of E:\« 
jjfei \management \CVS 



\ES\src\java\net\espeak\je 



==^12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s; 



1, 191 
63 
46 
846 



Entries 

Repository 

Root 

Template 



2, 146 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\s« 
rvices 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:26p 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 

<DIR> 
<DIR> 



advertise 
149 compile.bat 
CVS 

events 
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12/07/99 
12/06/00 
12/06/00 



04:26p 
04:33p 
04:33p 
9 



test 

269 Makefile 
<DIR> management 
<DIR> tunnel 
File(s) 418 bytes 



rvices\advertise 




12/06/00 


04 




<DIR> 


12/06/00 


04 


• ^ VJ 


<DIR> 


12/06/00 


04 




<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


□12/06/00 


04 


: 33p 


<DIR> 


fll2/07/99 


04 


:26p 




^^ll2/07/99 


04 


:26p 




W12/07/99 


04 


:26p 




W12/06/00 


04 


: 33p 


<DIR> 


012/06/00 


04 


: 33p 


<DIR> 


^==^12/06/00 


04 


:33p 


<DIR> 


^^2/06/00 


04 


: 33p 


<DIR> 



17 File(s) 



agents 
bin 

clientapi 
1,055 compile. bat 
143 co.MYCOs 
CVS 

discovery 

exception 
325 Makefile 
668 makefile . release 
131 object-class-definition 

query__parser 

util 

ypcommon 
ypserver 
2,322 bytes 



( Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
::rvices\advertise\agents 



AdvLSAgent . j ava 
BackendAgentlntf . java 
CVS 

LDAPDirAgent . j ava 
Makefile 

ProxySocketFactory . java 
72,183 bytes 



^=12/06/00 


04 


: 33p 


<DIR> 




^12/06/00 


04 


:33p 


<DIR> 




12/07/99 


04 


:26p 




14,434 


12/07/99 


04 


:26p 




5,019 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




45, 917 


12/07/99 


04 


: 2 6p 




441 


12/07/99 


04 


: 26p 




6,372 



File(s: 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\advertise\agents\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 



<DIR> 
<DIR> 



272 Entries 
73 Repository 
4 6 Root 
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12/06/00 


04 


:33p 


12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


012/07/99 


04 


:26p 


m2/07/99 


04 


:26p 






13 



12/16/99 06:20p ^^846 Template 

6 File(s) 1,237 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\s 
rvices\advertise\bin 

<DIR> 
<DIR> 

<DIR> CVS 

607 runas_ldap.bat 
640 runas_ldap 
599 runas_noldap 
580 runas_noldap.bat 
585 runas_ldap_s 
54 9 runas_ldap_s.bat 
585 runas_ldap_i_s 
549 runas_ldap_i~s.bat 
673 runas_ldap_i 
635 runas_ldap_i.bat 
File(s) 6,002 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\s 
=rvices\advertise\bin\CVS 

yi2/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

:i2/16/99 06:20p 513 Entries 

^2/16/99 06:20p 70 Repository 

S12/16/99 05:20p 46 Root 

512/16/99 06:20p 846 Template 

% 6 File(s) 1,475 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\s 
rvices\advertise\clientapi 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 23,009 ESADServicelnterf ace . j ava 

12/07/99 04:26p 376 Makefile 

5 File(s) 23,385 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\s 
rvices\advertise\clientapi\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 110 Entries 



Page 7 6 



12/16/99 
12/16/99 
12/16/99 



06:20p 
06:20p 
06:20p 

6 File(s) 



test 

76 Repository 
4 6 Root 
84 6 Template 
1,078 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\ 
rvices\advertise\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:21p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File (s) 



254 Entries 
158 Entries. Log 
66 Repository 
46 Root 
84 6 Template 
1,370 bytes 



3 Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
-iirvices\advertise\discovery 



^2/06/00 04:33p <DIR> 

AiL2/06/00 04:33p <DIR> 

□12/07/99 04:26p 

=^12/07/99 04:26p 

m2/07/99 04:26p 

a2/07/99 04:26p 

^=12/07/99 04:26p 

3.2/07/99 04:26p 

312/07/99 04:26p 

SL2/07/99 04:26p 

i2/07/99 04:26p 

42/07/99 04:26p 

12/06/00 04:33p <DIR> 

12/07/99 04:26p 

14 File(s) 



4,005 AdvDscvMsgBag. java 
1,992 AdvDscvMsg, java 
4,022 AdvIncomingDscvRqst . java 
4,575 AdvIncomingDscvRply . java 
12, 183 AdvMcastSenderReceiver. java 
3,810 AdvOutgoingDscvRqst . java 
7,247 AdvOutgoingDscvRply. java 
4,524 AdvSLPOutgoingMsg. java 
3,336 AdvSLPMsg. java 
7,123 AdvSLPIncomingMsg. java 
CVS 

640 Makefile 
53,457 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\s 
rvices\advertise\discovery\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



632 Entries 
7 6 Repository 
4 6 Root 
846 Template 
1,600 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\s 
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test 



rvices\advertise\exception 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
9 



<DIR> 
<DIR> 



<DIR> 



File (s) 



3,118 AdvException. java 
3,237 AdvNoSuchBackendExcept ion. java 
CVS 

3,089 IllegalArgument. java 

490 Makefile 
3,175 NoADServiceExcept ion. java 
3,148 ParseErrorException. java 
16,257 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\advertise\exception\CVS 



12/06/00 
112/06/00 
112/16/99 
112/16/99 
J12/16/99 
J12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



349 Entries 
7 6 Repository 
46 Root 

84 6 Template 
1,317 bytes 



J Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\se 
rvices\advertise\query_parser 



ilt2/06/00 


04 


: 33p 


<DIR> 








^:-a2/06/00 


04 


: 33p 


<DIR> 








^^2/06/00 


04 


: 33p 


<DIR> 




CVS 




^□12/07/99 


04 


:26p 




2, 505 


LDAPQueryOps . j ava 




^a2/07/99 


04 


:26p 




747 


Makefile 




12/07/99 


04 


:26p 




3,408 


QueryLeaf Node . j ava 




12/07/99 


04 


:26p 




4,285 


QueryAndNode . j ava 




12/07/99 


04 


:26p 




5, 451 


QueryComparatorNode . 


j ava 


12/07/99 


04 


:26p 




4,077 


QueryExprNode . j ava 




12/07/99 


04 


:26p 




3, 667 


QueryEqNode . j ava 




12/07/99 


04 


:26p 




3,095 


QueryGtNode . j ava 




12/07/99 


04 


:26p 




3,101 


QueryGeNode . j ava 




12/07/99 


04 


:26p 




2,252 


Queryldentif ierNode . 


java 


12/07/99 


04 


:26p 




3,073 


QueryLtNode . j ava 




12/07/99 


04 


:26p 




2, 636 


QueryLiteralNode . j ava 


12/07/99 


04 


:26p 




17,430 


QueryLex. java 




12/07/99 


04 


:26p 




3,097 


QueryLeNode . j ava 




12/07/99 


04 


:26p 




3,498 


QueryNotNode . j ava 




12/07/99 


04 


:26p 




3,825 


QueryNeqNode . j ava 




12/07/99 


04 


: 26p 




4,373 


QueryOrNode . j ava 




12/07/99 


04 


:26p 




14,678 


QueryParser . j ava 
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Ei 



21 File(s) 



test 

85,198 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\advertise\query parser\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
G6:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



975 Entries 
79 Repository 
46 Root 

846 Template 
1,946 bytes 



Directory of E : \e-speak-src_9 91217 \plat f orm\ES\src\j ava\net\espeak\se 
rvices\advertise\util 



12/06/00 


04 


:33p 


<DIR> 




i312/06/00 


04 


: 33p 


<DIR> 




#12/06/00 


04 


:33p 


<DIR> 


CVS 


^Jl2/07/99 


04 


:26p 




3,428 eskill.java 


UJ12/07/99 


04 


:26p 




424 Makefile 


W12/07/99 


04 


:26p 




5,560 Multicaster . java 


□12/07/99 


04 


:26p 




2,191 Shutdownlntf . java 


!=^12/07/99 


04 


:26p 




6,600 ShutdownCtrl. java 






8 File(s; 




18,203 bytes 



^; Directory of E:\e-speak-src 991217\platf orm\ES\src\ j ava\net \espeak\se 
Jrvices\advertise\util\CVS 



^^12/06/00 
=112/06/00 
i2/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



257 Entries 
71 Repository 
4 6 Root 

84 6 Template 
1,220 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\se 
rvices\advertise\ypcoinmon 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:2 6p 
04:26p 
04 :33p 
04:26p 
04:26p 
04:26p 



<DIR> 
<DIR> 



<DIR> 



2,24 9 AdvDebug , j ava 
6,157 ArraySet . java 
CVS 

Makefile 
QueryOps . j ava 
YPCompBigDecimal . j ava 



689 
2, 465 
2,537 

79 



Page 









test 




12/07/99 


04 


:26p 


2, 451 


YPCompFloat . j ava 


12/07/99 


04 


: 26p 


9, 801 


y PComparator . j ava 


12/07/99 


04 


:26p 


2, 430 


YPCompByte . j ava 


12/07/99 


04 


: 26p 


2, 442 


YPComDDouble iava 


12/07/99 


04 


:26p 


2, 566 


YPComDarablF^ iava 

1* Nh/X i L J« Xh/ Smi^ • 1 La V LA 


12/07/99 


04 


: 2 6p 


2, 353 


YPConriDSI' r i ncf i;^v;^ 


12/07/99 


04 


:26p 


2,430 




12/07 /99 


04 


: 26p 


2,418 


YPCompLong • j ava 


12/07/99 


04 


:26p 


2,439 


YPCompInt . j ava 


12/07/99 


04 


: 26p 


2,504 


YPCompChar . j ava 


12/07/99 


04 


:26p 


2,087 


YPObjects . java 


12/07/99 


04 


:26p 


2,745 


YPOperations . j ava 






20 File(s) 


50,763 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ 
rvices\advertise\ypcommon\CVS 



112/06/00 
a2/06/00 
U2/16/99 
^12/16/99 
112/16/99 
112/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



890 Entries 
75 Repository 
4 6 Root 

84 6 Template 
1,857 bytes 



Directory of E: \e-speak-src_991217\platforin\ES\src\ java\net\espeak\ 
^rvices\advertise\ypserver 



^12/06/00 
^12/06/00 
^^12/07/99 
^12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
16 



<DIR> 
<DIR> 



<DIR> 



File(s; 



8 8,2 92 Advert isingService. java 
4,168 BackendLookupResult . java 
5,140 BackendConnectionInf o . j ava 

16,210 ConnectionManager . java 
CVS 

4,733 ExternalEsrl . java 

651 Makefile 
4,138 TimeoutHandler . java 
5,34 6 YPGenericTable. java 
5,438 YPIterasTable. java 
4,980 YPItem.java 
3,221 YPMessage. java 
3,821 YPSearchResultsTable. java 
9,852 YPSearchResult. java 
155,990 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ 
rvices\advertise\ypserver\CVS 
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test 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 728 Entries 

12/16/99 06:21p 75 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,695 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\se 
rvices\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 

12/16/99 06:21p 

12/16/99 06:20p 

i3l2/16/99 06:20p 

^012/16/99 06:20p 
^^1 7 File(s) 

Directory of E:\e-speak-src_991217\platforni\ES\src\java\net\espeak\se 



Cervices \e vents 






^12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




^"'U2/07/99 


04 :26p 




697 compile.bat 


n'12/06/00 


04:33p 


<DIR> 


CVS 


^^?12/07/99 


04:26p 




5,926 ESCoreDistributor . java 


■^2/07/9 9 


04:26p 




5, 093 ESManagementDistributor . java 


^-■12/07/99 


04:26p 




3,995 ESServiceDistributor. java 


^=jl2/07/99 


04:26p 




465 Makefile 


12/07/99 


04:26p 




510 makefile. release 




9 File{s: 


1 


16, 686 bytes 



96 Entries 
71 Entries. Log 
56 Repository 
4 6 Root 
84 6 Template 
1,115 bytes 



Directory of E:\e-speak-src 991217\platf orm\ES\src\ j ava\net \espeak\se 
rvices\events\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 335 Entries 

12/16/99 06:21p 63 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,290 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices \management 
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test 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/07/99 


04 


:26p 




1,328 


coitipile.bat 


12/06/00 


04 


: 33p 


<DIR> 




coreiuanager 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/06/00 


04 


: 33p 


<DIR> 




logger 


12/07/99 


04 


:26p 




333 


Makefile 


12/07/99 


04 


:26p 




759 


makefile . release 


12/06/00 


04 


:33p 


<DIR> 




policymanager 


12/06/00 


04 


:33p 


<DIR> 




processmanager 


12/06/00 


04 


: 33p 


<DIR> 




servicemanager 


12/06/00 


04 


: 33p 


<DIR> 




web 



12 File(s) 2,420 bytes 



Directory of E: \e-speak-src_991217\platf orin\ES\src\java\net\espeak\se 
rvices\management\coremanager 













* 






■ D O U 










04 


: 25p 




77 


i_ dud-iiciy t; j_ • j a. v d 


UII2/07/99 


04 


:26p 




20, 917 


CoreManagerMSImpl . j ava 


a2/07/99 


04 


:26p 




12, 661 


CoreManagerOS . j ava 


K2/07/99 


04 


:26p 




19,588 


CoreManagerMS . j ava 


illL2/07/99 


04 


:26p 




705 


compile .bat 


12/07/99 


04 


:26p 




7,599 


CoreEventSubscriberlmpl . java 


i'^2/07/99 


04 


:26p 




5,247 


CoreEventSubscriber . j ava 


1112/07/99 


04 


:26p 




7,420 


CoreManagerTags . j ava 


^12/07/99 


04 


:26p 




6, 473 


CoreManagerStat s . j ava 


W2/07/99 


04 


:26p 




4,484 


CoreManagerOSInt f . j ava 


^3.2/07/99 


04 


:26p 




23, 110 


CoreManagerOSImpl . j ava 


^=12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




4, 148 


DbgLog, java 


12/07/99 


04 


:26p 




6,249 


Event Publisher . java 


12/07/99 


04 


:26p 




8, 116 


ExtEventSubscriberlmpl . j ava 


12/07/99 


04 


:26p 




4, 622 


ExtEventSubscriber . j ava 


12/15/99 


04 


:00p 




931 


Makefile 


12/07/99 


04 


:26p 




527 


makefile . release 


12/07/99 


04 


:26p 




5, 151 


ServiceDataList . j ava 


12/07/99 


04 


:25p 




3, 528 


Shutdown. java 


12/07/99 


04 


:26p 




5,112 


StateMC. java 


12/07/99 


04 


:26p 




4, 434 


Staticinf o . j ava 


12/07/99 


04 


:25p 




10,091 


StatsReader . java 


12/07/99 


04 


: 2 6p 




3,785 


Stat sStore . j ava 


12/07/99 


04 


: 26p 




6, 651 


UpdateStats .java 






27 


File(s) 


199,202 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
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test 

rvices\inanagement\coremanager\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 1,324 Entries 

12/16/99 06:21p 79 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 2,295 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 149 Entries 

12/16/99 06:21p 121 Entries. Log 

^12/16/99 06:21p 67 Repository 

^12/16/99 06:21p 46 Root 

il2/16/99 06:21p 846 Template 

; 7 File(s) 1,229 bytes 

^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
^ rvices \management \logger 



^' 12/06/00 


04 


: 33p 


<DIR> 




1^12/06/00 


04 


:33p 


<DIR> 




™12/06/00 


04 


: 33p 


<DIR> 


client 


yi2/06/00 


04 


: 33p 


<DIR> 


CVS 


^ffl2/07/99 


04 


:26p 




333 Makefil 


9l2/06/00 


04 


: 33p 


<DIR> 


manager 


^-^12/06/00 


04 


: 33p 


<DIR> 


message 


12/06/00 


04 


: 33p 


<DIR> 


service 


12/06/00 


04 


: 33p 


<DIR> 


test 


12/06/00 


04 


: 33p 


<DIR> 


types 


12/06/00 


04 


: 33p 


<DIR> 


util 






11 File(s, 




333 bytes 



Directory of E : \e-speak-src_991217 \plat f orm\ES\src\ j ava\net \espeak\se 
rvices \management\logger\client 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 4,325 ESLogClient . java 

12/15/99 04:00p 434 Makefile 

5 File(s) 4,759 bytes 
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test 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\s 
rvices\management\ logger \client\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 101 Entries 

12/16/99 06:21p 81 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File (3) 1,074 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\s 
rvices\management\logger\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 48 Entries 

312/16/99 06:21p 110 Entries. Log 

312/16/99 05:21p 74 Repository 

^12/16/99 06:21p 46 Root 

yi2/16/99 06:21p 846 Template 

i! 7 File(s) 1,124 bytes 

= Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\s 
^^rvices\management\logger\manager 



CVS 



:fl2/06/00 


04 


: 33p 


<DIR> 




^hl2/06/00 


04 


:33p 


<DIR> 




^=42/06/00 


04 


: 33p 


<DIR> 




^42/07/99 


04 


:26p 




9,765 


1^2/07/99 


04 


: 26p 




69 


H2/07/99 


04 


:26p 




7, 964 


12/15/99 


04 


: OOp 




473 



7 File(s) 18,271 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\s 
rvices\management\logger\manager\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 237 Entries 

12/16/99 06:21p 82 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,211 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\s. 
rvices\management\logger\message 



Page 84 



test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
5 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

13,666 ESLogMessage. java 
405 Makefile 
14,071 bytes 



Directory of E: \e-speak-src_991217\platforni\ES\src\java\net\espeak\se 
rvices\management\logger\message\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



102 Entries 
82 Repository 
4 6 Root 

846 Template 
1,076 bytes 



I Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
lrvices\management\logger\service 



312/06/00 04:33p <DIR> 

-■12/06/00 04:33p <DIR> 

yi2/06/00 04:33p <DIR> 

12/07/99 04:26p 

=^12/07/99 04:26p 

U12/07/99 04:26p 

3l2/07/99 04:26p 

B12/07/99 04:26p 

312/07/99 04:26p 
=J. j ava 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

17 File(s) 



CVS 

18 , 657 ESLogFileWriter . j ava 

3,693 ESLoggerWaitQueue . java 

16,773 ESLogMessageParser. java 

2,281 ESLogServicelntf .esidl 

4,131 ESLogServiceStub. java 

1, 135 ESLogServicelntf MessageRegistry 

2,281 ESLogServicelntf . java 

3,737 ESLogServicelmpl . java 

741 Makefile 

2, 727 ServicePackageWhiteBoxTest .java 

4,995 TestDenialOf Service. java 

4,380 TestEscapeProcessing. java 

12,892 Test FileWriting. java 

6,023 TestQueueProcessing. java 
84,446 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\logger\service\CVS 



12/06/00 04:33p 
12/06/00 04:33p 
12/16/99 06:21p 



<DIR> 
<DIR> 



839 Entries 
Page 85 



12/16/99 
12/16/99 
12/16/99 



06:21p 
06:21p 
06:21p 

6 File(s; 



test 

82 Repository 
4 6 Root 
84 6 Template 
1,813 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
rvices\management\ logger \test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
6 



<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 

2,058 ESLoggerTest . java 
4,297 ESLoggerDefaultTest . java 
403 Makefile 
6,758 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
rvi ces\management\ logger \t est \CVS 



il2/06/00 
i 12/06/00 
^12/16/99 
^12/16/99 
=12/16/99 
il2/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s; 



163 Entries 
7 9 Repository 
4 6 Root 

846 Template 
1,134 bytes 



f Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
-rvices\management\logger\types 



-^2/06/00 


04 


:33p 


<DIR> 








-^2/06/00 


04 


:33p 


<DIR> 








12/06/00 


04 


:33p 


<DIR> 






CVS 


12/07/99 


04 


: 2 6p 




3, 


888 


ESLoggableDataltem. java 


12/07/99 


04 


:26p 




4, 


928 


ESLoggableDataltemList . j ava 


12/07/99 


04 


:26p 




3, 


485 


ESLoggableBoolean . j ava 


12/07/99 


04 


:26p 




3, 


481 


ESLoggableString . j ava 


12/07/99 


04 


:26p 




3, 


531 


ESLoggablelnteger . j ava 


12/07/99 


04 


:26p 




3, 


529 


ESLoggableFloat . j ava 


12/07/99 


04 


:26p 




4, 


459 


ESLoggableDate . j ava 


12/07/99 


04 


:26p 






547 


Makefile 






11 


File (s) 


27 


, 84i 


3 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
rvices\management\logger\types\CVS 



12/06/00 
12/06/00 



04:33p 
04:33p 



<DIR> 
<DIR> 
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12/16/99 
12/16/99 
12/16/99 
12/16/99 



06:21p 
06:21p 
06:21p 
06:21p 
6 



test 
461 
80 
46 
846 



File (s; 



Entries 

Repository 

Root 

Template 



1,433 bytes 



Directory of E: \e-speak-src_991217\platforin\ES\src\java\net\espeak\se 
rvices\management\logger\util 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04 : 33p 
04:26p 
04:26p 
5 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

2,286 ESLoggableDateFormat . java 
381 Makefile 
2,667 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
Irvices \management Mogger \ut il \CVS 



112/06/00 
112/06/00 
112/16/99 
112/16/99 
^12/16/99 
J12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



110 Entries 
79 Repository 
4 6 Root 

846 Template 
1,081 bytes 



fe- Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rj:vices\management\policymanager 



a2/06/00 


04:33p 


<DIR> 




a2/06/Q0 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/15/99 


04:00p 




1,397 


12/07/99 


04:26p 




2,330 


a 

12/07/99 


04:26p 




2,207 


12/07/99 


04:26p 




5,198 


12/07/99 


04:26p 




30,027 


12/07/99 


04:26p 




2,145 


ava 








12/07/99 


04:26p 




3,828 


12/07/99 


04:26p 




4,792 


12/07/99 


04:26p 




2,819 


12/07/99 


04:26p 




2,708 


12/07/99 


04:26p 




1,817 


Registry. 


java 







CVS 

f ilingsystem 



PolicyLif ecycleEvent . j ava 
PolicyManagerlntf . j ava 
PolicyManagerLinkageEvent . j ava 
PolicyManagerLoopException , j ava 
PolicyManagerFactorylntf Message 
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test 


12/07/99 


04 :26p 




6,568 


12/07/99 


04:26p 




2,392 


12/07/99 
a 


04:26p 




3,000 


12/07/99 


04:26p 




2,400 


12/07/99 


04:26p 




2,694 


. java 








12/07/99 


04:26p 




2,247 


java 








12/07/99 


04 :26p 




2,225 


va 








12/07/99 


04:26p 




2,219 


12/07/99 


04:26p 




2, 549 


. j ava 








12/07/99 


04:26p 




1,394 


y. java 








12/07/99 


04:26p 




5,720 


□12/07/99 


04:26p 




24,384 


012/07/99 


04:26p 




4, 792 


^Jl2/07/99 


04:26p 




6, 112 


ijl2/07/99 


04:26p 




2,188 


:jJtener . java 






312/07/99 


04:26p 




2,069 


"'nt . j ava 








m2/06/00 


04:33p 


<DIR> 





1,394 PolicyManagerlntfMessageRegistr 



32 File(s) 



2, 069 PolicyManagerFactoryShutdownEve 

servlet 
132,221 bytes 



i Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
^rvices\management\policymanager\CVS 



^=42/06/00 


04:33p 


<DIR> 




□12/06/00 


04:33p 


<DIR> 




12/16/99 


06:21p 




1,805 


12/16/99 


06:21p 




39 


12/16/99 


06:21p 




81 


12/16/99 


06:21p 




46 


12/16/99 


06:21p 




846 



7 File(s) 



2,817 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\inanagement\policymanager\filingsystem 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
va 

12/06/00 



04:33p 
04:33p 
04:26p 
04:26p 

04:33p 



<DIR> 
<DIR> 



<DIR> 



8,047 ChangeList . java 

1, 931 CorruptedPolicyFileException. ja 



CVS 
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12/07/99 04:26p 
12/07/99 04:26p 
12/07/99 04:26p 
12/07/99 04:26p 
j ava 

12/07/99 04:26p 
properties 
12/15/99 04:00p 
12/07/99 04:26p 

12 File(s) 



test 

13,747 FileFormatter. java 

9,032 FileLoader . java 

5,168 FileUtil. java 

17,791 FilingSystemPersistencyManager . 

33 FilingSystemPersistencyManager , 

590 Makefile 

11,933 PolicyManagerFile. java 
68,272 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\management\policyraanager\f ilingsystem\CVS 



12/06/00 
12/06/00 
12/16/99 
312/16/99 
D12/16/99 
^112/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



536 Entries 
94 Repository 
46 Root 

846 Template 
1,522 bytes 



3 Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
=-=rvices\management\policymanager\servlet 



12/06/00 
-12/06/00 
142/06/00 
"42/15/99 
^12/07/99 



04:33p 
04:33p 
04:33p 
04:00p 
04:26p 
5 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

424 Makefile 
16,601 PolicyManagerServlet . java 
17,025 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\management \policymanager\servlet \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



110 Entries 
8 9 Repository 
4 6 Root 

84 6 Template 
1,091 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\management\processmanager 



12/06/00 
12/06/00 



04:33p 
04:33p 



<DIR> 
<DIR> 
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mmmmmn vwrnw n.i 



test 



1 o f (\Ci / r\r\ 


04 : 33p 


<DIR> 


CVS 




04 : 2 bp 




34 9 Makefile 


/ U 0/ U U 


n /I . o o« 

U4 : J Jp 


<DIR> 


service 


12/06/00 


04 " 33n 




sneli 


12/06/00 


04:33p 


<DIR> 


statemonitor 


12/06/00 


04:33p 


<DIR> 


test 


12/06/00 


04:33p 


<DIR> 


util 


12/06/00 


04 :33p 


<DIR> 


web 




10 


File(s) 


349 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\management\processinanager\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 
7 



<DIR> 
<DIR> 



File{s) 



4 8 Entries 
95 Entries. Log 
82 Repository 
4 6 Root 
84 6 Template 
1,117 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
;rvices\management\processmanager\ service 



12/06/00 04:33p 

U2/06/00 04:33p 

^12/06/00 04:33p 

;i2/07/99 04:26p 

^2/07/99 04:26p 

^12/07/99 04:26p 

^12/07/99 04:25p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

eRegistry. java 

12/07/99 04:26p 

12/07/99 04:26p 

12 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

652 Makefile 
2, 226 ProcessManagerExcept ion. java 
4,494 ProcessManager. java 
5, 155 ProcessManagerServicelntf .esidl 
8, 380 ProcessManagerServiceStub. java 
1, 923 ProcessManagerException. esidl 
1, 393 ProcessManagerServicelntfMessag 

5, 155 ProcessManagerServicelntf . java 
10, 069 ProcessManagerService. java 
39,447 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
rvices\management\processmanager\service\CVS 



se 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 



<DIR> 
<DIR> 



582 Entries 
90 Repository 
4 6 Root 
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12/16/99 



06:21p 
6 



File(s) 



test 

84 6 Template 
1,564 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\inanageraent\processmanager\shell 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
7 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

427 Makefile 
11,963 PMShellService. java 
24,700 PMShellConsole. java 

4,103 PMShell.java 

41,193 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ 
rvices\management\processmanager\shell\CVS 



se 



il2/06/00 
112/06/00 
112/16/99 
112/16/99 
'12/16/99 
^12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



209 Entries 
88 Repository 
4 6 Root 

84 6 Template 
1,189 bytes 



: Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
^rvices\management\processmanager\statemonitor 



^12/06/00 
:fl2/06/00 
^12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

15 File(s) 



<DIR> 
<DIR> 

<DIR> 



4,182 CoreConnectionMonitor . java 
CVS 

3,129 ESJoblntf . java 
1,8 68 ES Job. java 
3,731 InJVMJob. java 

641 Makefile 
4,007 MonitorlniFile. java 
5,2 60 Process Job. java 
3,947 StateMonitorlntf . java 
1, 794 StateMonitorException . j ava 
4,679 StateMonitorConfig. java 
3,468 StateMonitor . java 
5,362 TaskErrStreamMonitor. java 
42,068 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\processmanager\statemonitor\CVS 
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test 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



664 Entries 
95 Repository 
4 6 Root 
846 Template 
1,651 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\management\processmanager\test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
^2/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
6 



<DIR> 
<DIR> 
<DIR> 



File (3) 



CVS 

378 Makefile 
176 TEST.ESH 
2,416 TestTask. java 
2,970 bytes 



I Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\se 
;;rvices\management\processmanager\test\CVS 



'12/06/00 
^12/06/00 
12/16/99 
^12/16/99 
^12/16/99 
^12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
05:21p 
6 



<DIR> 
<DIR> 



File (s) 



143 Entries 
87 Repository 
4 6 Root 

846 Template 
1,122 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\processmanager\util 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
9 



<DIR> 
<DIR> 



<DIR> 



File(s) 



3,136 ClientHelper . java 
3,815 CommandLine . java 
CVS 

3,272 InJVMRunner . java 
2,97 9 lOPipe.java 

493 Makefile 
3,715 SimpleLoader . java 
17,410 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\processmanager\util\CVS 
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12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



test 



310 Entries 
87 Repository 
4 6 Root 
84 6 Template 
1,289 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\processmanager\web 



12/06/00 
12/06/00 
12/06/00 
12/15/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:00p 
04:26p 
04:26p 
6 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

447 Makefile 
12,009 PMShellServlet. java 
129 servlet .properties 
12,585 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
^tvices\management\processmanager\web\CVS 



42/06/00 
fl2/06/00 
^2/16/99 
12/16/99 
:*a2/16/99 
HL2/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



159 Entries 
86 Repository 
4 6 Root 

84 6 Template 
1,137 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
^vices\management\servicemanager 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
ava 

12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 

04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 



<DIR> 
<DIR> 
<DIR> 



CVS 

848 Makefile 
9,820 ServiceManager . java 
3 , 322 ServicelnstanceManager . j ava 
9,858 ServiceEventHandler . j ava 
2, 093 ServicelnstanceManagerFailure. j 

2, 142 ServiceControllerFailure. java 

2, 082 ServiceEventHandlerFailure. java 

7,351 ServiceController . java 

2,289 ServiceManagerlntf .esidl 

5,091 ServiceManagerStub . j ava 

1,273 ServiceManagerlntf MessageRegist 
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test 

ry . j ava 

12/07/99 04:26p 2,318 ServiceManagerlntf . java 

12/07/99 04:26p 2,714 ServiceManagerlmpl . i ava 

12/06/00 04:33p <DIR> ui 

17 File(s) 51,201 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\ 
rvices\management\serviceraanager\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 809 Entries 

12/16/99 06:21p 12 Entries. Log 

12/16/99 06:21p 82 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

7 File(s) 1,795 bytes 

0 Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
'-^rvices \management \servicemanager \ui 



1,888 ChangeStateFailed. java 
CVS 

842 Makefile 
2,036 ModelExcept ion. java 
6,8 67 ServiceManagerUI . java 
3,470 ServiceManagerTableModel .java 
15,099 ServiceManagerServlet .java 
21,904 ServiceManagerModel . java 
193 servlet .properties 
8,894 UiServiceManagerAdapter . j ava 
6,577 UiServiceManager . java 
67,770 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\; 
rvices\management\servicemanager\ui\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 589 Entries 

12/16/99 06:21p 85 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,566 bytes 



W12/06/00 


04:33p 


<DIR> 


012/06/00 


04:33p 


<DIR> 


^=^12/07/99 


04:26p 




-12/06/00 


04:33p 


<DIR> 


12/15/99 


04:00p 




!fl2/07/99 


04:26p 




%2/07/99 


04:26p 




H2/07/99 


04:26p 




^12/07/99 


04:26p 




:=l2/07/99 


04:26p 




■42/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 






13 File 


(s) 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\ 
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rvices \management \web 



test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> servlets 

4 File(s) 0 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\se 
rvxces\management\web\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 3 Entries 

12/16/99 06:21p 18 Entries. Log 

12/16/99 06:21p 71 Repository 

12/16/99 06:21p 46 Root 

□12/16/99 06:21p 846 Template 

y 7 File(s) 984 bytes 

iJ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
A^rvices\management\web\servlets 

-^2/06/00 04:33p <DIR> 
U12/06/00 04:33p <DIR> 

12/07/99 04:26p 7,457 CoreServlet . java 

=^12/06/00 04:33p <DIR> cvs 

yi2/15/99 04:00p 461 Makefile 

^12/07/99 04:26p 10,758 Management Servlet . java 

Z 6 File(s) 18,676 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices \management \web \servlet s \CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 160 Entries 

12/16/99 06:21p 80 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,132 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvicesXtunnel 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:26p 6,943 AbstractSocket . j ava 
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test 


12/07/99 


04:26p 


1,894 


12/07/99 


04:26p 


2,219 


12/07/99 


04:26p 


1,781 


12/07/99 


04:26p 


2,525 


12/07/99 


04:26p 


2,428 


12/07/99 


04:26p 


700 


12/07/99 


04:26p 


2,227 


12/06/00 


04:33p <DIR> 


12/07/99 


04:26p 


6,227 


12/07/99 


04:26p 


3,218 


12/07/99 


04:26p 


2, 984 


12/07/99 


04:26p 


1,777 


12/07/99 


04:26p 


2,203 


12/07/99 


04:26p 


4,777 


12/07/99 


04:26p 


245 


12/07/99 


04:26p 


7,531 


12/07/99 


04:26p 


3, 970 


a2/07/99 


04:26p 


5, 860 


^2/07/99 


04:26p 


1, 861 


'^ll2/07/99 


04:26p 


3,210 


W2/07/99 


04:26p 


3, 413 


^^12/07/99 


04:26p 


2, 802 


^^42/07/99 


04:26p 


1, 114 


^^12/07/99 


04:26p 


0 


^^12/07/99 


04:26p 


518 


;■ 12/07/99 


04:26p 


1, 724 


^!^2/07/99 


04:26p 


2,789 


^}jl2/07/99 


04:26p 


2, 195 


^!42/07/99 


04:26p 


1, 674 


^2/07/99 


04:26p 


1, 686 


;i2/07/99 


04:26p 


1,788 


^42/07/99 


04:26p 


252 


12/07/99 


04:26p 


4, 534 


12/07/99 


04:26p 


2,782 


12/07/99 


04:26p 


6, 878 


12/07/99 


04:26p 


7,590 




39 File(s) 


106,319 



AcceptedSocket . java 
ByteArray. java 
ClientSocketFactorylF. java 
ClientSocketFactory . java 
ClientSocket .java 
compile.bat 

ConnectTunnelClientIF, java 
CVS 

Dialog. java 

ESClientSocketFactoryStub. java 
ESClientSocketFactorySkel .java 
ESClientSocketFactorylF. java 
ESConnectTunnelClientlF. java 
ESConnectionFinder . j ava 
esdriver 
ESDriver . java 
ESSocketStub . j ava 
ESSocketSkel. java 
ESSocketlF. java 
ESTunnelServiceStub . j ava 
ESTunnelServiceSkel . j ava 
ESTunnelServicelF. java 
Makefile 
Makefile.dep 
makefile . release 
ModellF. java 
PassiveSocket . j ava 
SimpleConnectionFinder . j ava 
SocketRegistrylF. java 
SocketlnternlF. java 
SocketlF. java 
tscmd 

TSCmd. java 

TunnelServicelF. java 
TunnelService , j ava 
TunnelAttributes . j ava 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvicesX tunnel \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s; 



2,001 Entries 

63 Repository 
4 6 Root 
84 6 Template 
2, 956 bytes 
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test 



11 






Iz/Ud/OO 


04 


: 33p 


lz/06/00 


04 


: 33p 


12/07/99 


04 


: 26p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


: 26p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/06/00 


04 


: 33p 


1312/07/99 


04 


:26p 


iyl2/07/99 


04 


:26p 


^^12/07/99 


04 


: 2 6p 


MJ12/07/99 


04 


:26p 


Lyi2/07/99 


04 


: 26p 


iDl2/07/99 


04 


:26p 


h^^^a2/07/99 


04 


:26p 


I1J12/07/99 


04 


:26p 


12/07/99 


04 


:2 6p 


^-^^^12/07/99 


04 


' 2 6p 


ilJl2/07/99 


04 


' 2 5p 


u.fl2/07/99 


04 


26p 


^ffl2/07/99 


04 : 


2 5p 


=312/07/99 


04: 


26p 


^^12/06/00 


04: 


33p 


12/15/99 


04 : 


OOp 


12/06/00 


04 : 


33p 


12/07/99 


04 : 


2 6p 


12/07/99 


04 : 


2 6p 


12/07/99 


04 : 


2 6p 


12/07/99 


04 : 


2 6p 


12/07/99 


04 : 


2 6p 


12/07/99 


04 : 


26p 


1 9 /m /QQ 


U4 : 


o r 

Zop 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


2 6p 


12/07/99 


04: 


2 6p 


12/07/99 


04: 


26p 


12/06/00 


04: 


33p 



<DIR> 
<DIR> 



<DIR> 



<DIR> 



<DIR> 
<DIR> 



<DIR> 



6, 191 Assert . java 
2,023 Codecoverage. java 
2,289 CoverageThread. java 
CVS 

3,729 ErrorMsg. java 
15,301 ESAbstractWriter. java 

9,088 ESArray.java 

2,605 ESContainer . java 
26,220 ESDebug.java 

5,855 ESFileWriter. java 
esidl 

6,271 ESList.java 

3,817 ESLogSt ream. java 

2,997 ESMapNode. java 
16,204 ESMap.java 

2,747 ESPrintWriter . java 

4,619 ESSet.java 

6,346 ESString. java 
10,178 ESStrings. java 
17,634 ESText.java 
14,600 ESTracer. java 

2,099 ExternalLogger . java 

6,221 FileServerServlet . java 

7,029 GenericListenerList . java 
19,890 IniFile.java 
io 

1,400 Makefile 
misc 

4,161 NullPrintStream. java 

4,350 Poll. java 
50,112 SysLoader . java 

6,639 Tas kin JVM. java 

3,64 6 TaskLoader . java 

8,240 Tas kNew JVM. java 

6,598 TaskRemote. java 

7,785 TaskReader . java 

4,939 TaskServer. java 

3,170 TaskWatcher. java 
32,665 Task. java 

3,430 TestHelper. java 

6,416 Trace. java 
ts 
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12/06/00 04:33p 
12/07/99 04:26p 

46 File(s) 



test 

<DIR> tsutil 

6,296 UniquelD. java 
343,800 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ut 



il\CVS 






12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:21p 


1,957 Entries 


12/16/99 


06:21p 


69 Entries. Log 


12/16/99 


06:21p 


52 Repository 


12/16/99 


06:21p 


4 6 Root 


12/16/99 


06:21p 


84 6 Template 




7 File(s) 


2,970 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ut 
lil\esidl 



412 
ill 2 
4ll2 
3l2 
=12 
tJl2 
12 
^12 
14 2 
'312 
Vl2 
3l2 
:iL2 
12 
12 



/06/00 
/06/00 
/07/99 
/06/00 
/07/99 
/07/99 
/07/99 
/07/99 
/07/99 
/07/99 
/07/99 
/07/99 
/07/99 
/07/99 
/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
15 



<DIR> 
<DIR> 

<DIR> 



File (s) 



11,106 CodeGen . j ava 
CVS 

32,286 IDLCompiler . java 

13,857 IDLTypeRepository . java 

3, 997 ImportedTypeRepository . j ava 

2,391 InvalidlDLTypeException. java 

593 Makefile 

20,659 Marshaller . java 

3,320 MyPrintWriter . j ava 

7,153 PrimitiveTypeMap . j ava 

18,662 StubCompiler . j ava 

18,593 TypeValidator. java 

14,618 Utils.java 

147,235 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ut 
il\esidl\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



659 Entries 
58 Repository 
46 Root 

846 Template 



1,609 bytes 

Directory of E:\e-speak-src 991217\platf orm\ES\src\j ava\net \espeak\ut 
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test 



il\io 



12/06/00 


04 




<nTR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


: 26p 




12/07/99 


04 


:26p 





10 File(s) 



CVS 

5,2 83 FileOutputStream. j ava 

4,154 LogContext . j ava 

8,302 LogEnv.java 

7,550 Logger. j ava 

4,571 LogOutputStream. java 

455 Makefile 
3,029 NullOutputStream. java 
33,344 bytes 



Directory of E:\e~speak-src 991217\platf orm\ES\src\ j ava\net \espeak\ut 
il\io\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 369 Entries 

12/16/99 06:21p 55 Repository 

^12/16/99 06:21p 46 Root 

^12/16/99 06:21p 846 Template 

6 File(s) 1,316 bytes 

Directory of E:\e-speak- src 9 912 17 \plat f ori[i\ES\src\ j ava\net \espeak\ut 

=il\misc 

'^2/06/00 04:33p <DIR> 

.^12/06/00 04:33p <DIR> 

112/07/99 04:26p 2,422 Array. java 

-12/07/99 04:26p 12,450 ByteArray . java 

12/07/99 04:26p 4,536 ByteBuf f er . j ava 

12/07/99 04:26p 10,566 Cons. java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 429 Makefile 

12/07/99 04:26p 5,387 Queue. java 

12/07/99 04:26p 2,042 Testable . java 

10 File{s) 37,842 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ut 
il\raisc\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:21p 

12/16/99 06:21p 

12/16/99 06:21p 



<DIR> 
<DIR> 

341 Entries 
57 Repository 
46 Root 
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12/16/99 06:21p 

6 File(s) 



test 

84 6 Template 
1,290 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ut 
il\ts 



/ U 0/ UU 


n /] 


: 6 op 


<UiK> 




• 


1 O / C\ C / C\C\ 


n yi 
U4 


: oop 


<DIK> 




• • 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


; 2 op 




not 

731 


Makefile 


12/07/99 


U4 


: 2 bp 




3^ 820 


PrettyPrintManager . j ava 


12/07/99 


04 


: 2 5p 




49^ 630 


TSAtomic. java 


12/07/99 


04 


:26p 




5, 305 


TSBoolean . j ava 


12/07/99 


04 


: 2 6p 




2^ 867 


TSDatePP. java 


12/07/99 


04 


: 26p 




2, 764 


TSDef aultFactory. java 


12/07/99 


04 


:26p 




3, 105 


TSFactory. java 


12/07/99 


04 


: 2 bp 




10,751 


TSLexical . java 


„; 12/07/99 


04 


: 26p 




18,143 


TSList . java 


012/07/99 


04 


:26p 




2,829 


TSMapEnumeration . j ava 


y 12/07/99 


04 


:26p 




28,181 


TSMap. java 


y 12/07/99 


04 


:26p 




3,044 


TSObservable . j ava 


UI12/07/99 


04 


:26p 




22,612 


TSParser . java 


i3l2/07/99 


04 


:26p 




2,237 


TSParseException . j ava 


Ma2/07/99 


04 


:25p 




2, 488 


TSPrettyPrinter . j ava 


11112/07/99 


04 


:26p 




6,701 


TSTest . java 


12/07/99 


04 


:26p 




30,139 


TSUtils. java 


i-^12/07/99 


04 


:26p 




8, 179 


TSValue. java 


iyl2/07/99 


04 


:26p 




3,771 


TSVisitor . java 


O12/07/99 


04 


:26p 




2,520 


TypeErrorException . j ava 






23 File{s 




209,817 bytes 



Directory of E: \e-speak.-src_991217\platf orm\ES\src\ java\net\espeak\ut 
il\ts\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 1,048 Entries 

12/16/99 06:21p 55 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,995 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ut 
il\tsutil 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:2 6p 
04:26p 
04:26p 
04:2 5p 
04:2 6p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
14 



File (s) 



test 

4 , 605 List . java 

498 Makefile 
4,88 9 Map. java 
11,159 Syn.java 
2,545 TSBinary. java 
2,335 TSBoolean. java 
2,342 TSInteger. java 
2,310 TSNumber. java 
2,225 TSString. java 
2,165 TSTag.java 
2,426 TSToken. java 
37,499 bytes 



ilUsSmc?S '^=^^""P^^^-"^^-''^217\platform\ES\src\java\net\espeak\ut 



12/06/00 
U2/06/00 
il2/16/99 
^2/16/99 
^12/16/99 
il2/16/99 



ACVS 

04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File {si 



532 Entries 
59 Repository 
4 6 Root 
846 Template 
1,483 bytes 



baccesf''^ 2^\^-^P^^k-src_991217\platform\ES\src\java\net\espeak\we 



^m2/06/00 
^312/06/00 
^^12/06/00 
^^12/07/99 
^-42/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/15/99 
12/07/99 
12/07/99 



04:33p 

04:33p 

04:33p 

04:26p 

04:26p 

04:33p 

04:26p 

04:26p 

04 :26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:33p 

04:26p 

04:00p 

04:26p 

04:26p 



<DIR> 
<DIR> 
<DIR> 



<DIR> 



<DIR> 



conf 

3,264 Converterlntf . java 
2,913 Converterlnfo. java 
CVS 

3,7 55 DispatchTable. java 
15,409 ESConverter. java 
10,988 ESFormMapper. java 
11,250 ESMapper. java 
2,067 ESMessageXml. java 
5,440 ESProcessor. java 
4,423 FormGenericMapper. java 
4,589 FormLoginMapper . java 
3,703 GenericMapper . java 
6,801 GenericConverter. java 

htdocs 
4,429 Mailbox. java 
1,385 Makefile 

634 makefile. release 
3,165 Mapperlnfo. java 
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test 




12/07/99 


04 


:26p 


2,573 


Mapper Intf . j ava 


12/07/99 


04 


:26p 


2;040 


Processorlntf . j ava 


12/07/99 


04 


:25p 


2,716 


Processor Info . java 


12/07/99 


04 


: 26p 


3,667 


Queue . java 


12/07/99 


04 


:2 6p 


2,257 


RequestBadRequest . j ava 


12/07/99 


04 


: 26p 


2,288 


RequestNot Found . j ava 


12/07/99 


04 


:26p 


2,265 


RequestNoContent . java 


12/07/99 


04 


:26p 


2,267 


RequestMultipleChoice . j ava 


12/07/99 


04 


:26p 


2,241 


RequestForbidden . j ava 


12/07/99 


04 


:2 6p 


4, 866 


ServiceDaeiuon . j ava 


12/07/99 


04 


:2 6p 


4, 779 


Servi ceTranslat or iava 


12/07/99 


04 


:2 6p 


3, 155 


ServiceTable . i ava 


12/07/99 


04 


;2 6p 


7, 992 


ServiceHandler . i ava 


12/07/99 


04 


:2 6p 


16, 885 


ServiceDispatcher . j ava 


12/07/99 


04 


: 2 6p 


5, 929 


SessionTable . j ava 


12/07/99 


04 


:26p 


2, 971 


Session. j ava 


12/07/99 


04 


:26p 


3, 732 


TranslationTable . j ava 


12/07/99 


04 


: 2 6p 


5,255 


ORTjRi ndpT "i^v^ 


D 12/07/99 


04 


:2 5p 


3, 455 


W X VX-I V—' 1 1 • J (Jt V u 


SJ 12/07/99 


04 


:26p 


7,845 


URLConverter . j ava 


ijj 12/07/99 


04 


:26p 


6,889 


Util . java 


W12/07/99 


04 


: 2 6p 


2,663 


WAExceptionInf 0. java 


012/07/99 


04 


:26p 


2,472 


WANameList . j ava 


M=12/07/99 


04 


:26p 


6,942 


WebAccess . j ava 


11112/07/99 


04 


:2 6p 


9,263 


XMLApp3 . java 



46 File(s; 



201,632 bytes 



j Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\we 
Jbaccess\conf 



^12/06/00 
^2/06/00 
12/06/00 
12/07/99 
12/06/00 



04:33p 
04:33p 
04:33p 
04:26p 
04:33p 
5 



<DIR> 
<DIR> 
<DIR> 

<DIR> 



File (s; 



CVS 

27,318 httpd.conf 
j serv 
27,318 bytes 



Directory of E: \e-speak;-src_991217\platform\ES\src\ java\net\espeak\we 
baccess\conf \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 

7 File{s) 



<DIR> 
<DIR> 



50 Entries 
15 Entries. Log 
62 Repository 
4 6 Root 
84 6 Template 
1,019 bytes 
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test 



Directory of E: \e-speak:-src_991217\platform\ES\src\ java\net\espeak;\we 
baccess\conf \ j serv 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 6,559 jserv.conf 

12/07/99 04:26p 12,790 j serv . properties 

12/07/99 04:26p 6,496 zone . properties 

6 File(s) 25,845 bytes 



Directory of E: \e-speak;-src_991217\platform\ES\src\java\net\espeak\we 
baccess\conf \ j serv\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

3112/16/99 06:21p 155 Entries 

312/16/99 06:21p 68 Repository 

J12/16/99 06:21p 46 Root 

J12/16/99 06:21p 846 Template 

J 6 File(s) 1,115 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\we 
iJbaccess\CVS 

=^^12/06/00 04:33p <DIR> 
1112/06/00 04:33p <DIR> 

312/16/99 06:21p 2,218 Entries 

512/16/99 06:21p 30 Entries. Log 

312/16/99 06:21p 57 Repository 

°l2/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

7 File(s) 3,197 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\we 
baccess\htdocs 



12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:2 6p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 





699 ask-lu-vocab . html 

703 ask-reg-vocab . html 

665 book-buying.html 

509 button-back-to-register.gif 
CVS 

11,638 ESPEAK.jpg 

886 green-ball - gif 

1,454 index.html 
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test 



12/07/99 


04 


:26p 


1,107 login-reply.html 


12/07/99 


04 


:26p 


1,102 logo.gif 


12/07/99 


04 


:26p 


1,265 lookup-form.html 


12/07/99 


04 


:26p 


691,318 maylOic.bmp 


12/07/99 


04 


:26p 


41,279 raaylOic.jpg 


12/07/99 


04 


:26p 


1,522 register-form.html 


12/06/00 


04 


:33p <DIR> 


servlets 


12/07/99 


04 


:26p 


148,992 web-espeak slides. ppt 


12/07/99 


04 


:26p 


5,346 welcomenew.gif 






19 File(s) 


908,485 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\we 
baccess\htdocs\CVS 



12/06/00 
12/06/00 
12/16/99 
il2/16/99 
il2/16/99 
il2/16/99 
=12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:21p 
06:21p 
06:21p 
7 



<DIR> 
<DIR> 



File(s) 



7 85 Entries 
18 Entries. Log 
64 Repository 
46 Root 

846 Template 
1,759 bytes 



Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\we 
ibaccess\htdocs\servlets 



-12/06/00 


04 


:33p 


IU12/06/00 


04 


: 33p 


□12/07/99 


04 


:26p 


W12/06/00 


04 


: 33p 


■5l2/07/99 


04 


:26p 


Q12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/15/99 


04 


:00p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 



<DIR> 
<DIR> 

<DIR> 



14 File{s) 



20 , 614 BookBroker . j ava 
CVS 

7,04 5 Forms. j ava 

6,64 5 HTML2XML. java 

4,089 IsItWorking. java 
575 Makefile 
40 proxy. cfg 
10,518 ProxyBarnes . j ava 
12,4 89 ProxyFatBrain. java 

3, 578 Proxylnfo. java 

5, 4 67 ShowRegistrationForm. java 

2,224 XMLDocTags. java 

73,284 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\we 
baccess\htdocs\servlets\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:22p 569 Entries 
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12/16/99 
12/16/99 
12/16/99 



06:22p 
06:22p 
06:22p 

6 File(s) 



test 

73 Repository 
4 6 Root 
84 6 Template 
1,534 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\perl 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <dIR> 
12/06/00 04:33p <dir> 
4 File(s) 



CVS 
plesi 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\perl\CVS 



12/06/00 
12/06/00 
112/16/99 
112/16/99 
112/16/99 
J12/16/99 
J12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 
7 



<DIR> 
<DIR> 



File (s) 



3 Entries 
15 Entries. Log 
36 Repository 
46 Root 
846 Template 
94 6 bytes 



U Directory of E:\e-speak-src_991217\platform\ES\src\perl\pl 



esi 



i--12/06/00 
^12/06/00 
012/07/99 
^312/07/99 
a2/07/99 
^312/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

17 File(s) 



<DIR> 
<DIR> 



<DIR> 



9,832 
10,309 
2,220 

18,584 

13,760 
8, 467 
7, 139 
7,051 

15,799 
2, 636 
4,849 
2,019 
2,701 
3, 179 

108,545 



ABI.pm 
abi2c.pl 
abi2txt.pl 
CVS 

ESLib.pm 
ESReader .pm 
ESUtil.pm 
ESWriter.pm 
logexpand.pl 
README . txt 
rtc.pl 
rts .pi 
sigbytes.pl 
tc.pl 
ts .pi 
bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\perl\plesi\CVS 
12/06/00 04:33p <DIR> 
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test 

12/06/00 04:33p <DIR> 

12/16/99 06:22p 639 Entries 

12/15/99 06:22p 42 Repository 

12/16/99 06:22p 46 Root 

12/16/99 06:22p 846 Template 

6 File(s) 1,573 bytes 

Directory of E:\e-speak-src_991217\platforin\ES\src\python 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> pyesi 

4 File{s) 0 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\python\CVS 



ri 12/06/00 


04:33p <DIR> 






:Bl2/06/00 


04:33p <DIR> 






'%il2/16/99 


06:22p 


3 


Entries 


L:;.12/16/99 


06:22p 


15 


Entries .Log 


yi2/16/99 


06:22p 


38 


Repository 


i;U2/16/99 


06:22p 


46 


Root 


i"I2/16/99 


06:22p 


845 


Template 




7 File(s) 


94? 


3 bytes 



Directory of E : \e-speak:-src_991217\platf orm\ES\src\python\pyesi 



:a2/o6/oo 


04 


: 33p 


<DIR> 




W12/06/00 


04 


: 33p 


<DIR> 




C112/06/00 


04 


: 33p 


<DIR> 


abi 


^512/06/00 


04 


:33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


io 


12/06/00 


04 


: 33p 


<DIR> 


net 


12/07/99 


04 


:26p 




25,590 README.txt 


12/06/00 


04 


: 33p 


<DIR> 


util 


12/07/99 


04 


:26p 




0 init .py 






9 


File(s) 


25,590 bytes 


Directory of E:\e-speak-src_! 


991217 \platform\ES\sri 


12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


:2 6p 




17,585 abi.py 


12/07/99 


04 


:26p 




2,480 abi2txt.py 


12/07/99 


04 


:25p 




48,218 abiobj .py 


12/06/00 


04 


:33p 


<DIR> 


CVS 


12/07/99 


04 


:26p 




18,088 eslib.py 
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test 


12/07/99 


04:26p 


6,762 esobj.py 


12/07/99 


04 :25p 


2,476 esutil.py 


12/07 /99 


04 : 26p 


9 92S PS iriDnt" st'TPsnn r>v 


12/07/99 


0 4 : 2 6p 


11.082 es outmil" sI'TPsm nv 


12/07/99 


04:26p 


10,554 genabi.py 


12/07 /99 


04 : 26p 


7 0 9 f-^ (TP^noHn ov 


12/06/00 


04-330 <DIR> 




12/01 /99 


04 • 26d 


S 049 rtr nv 


12/07/99 


04 :26p 


10 , 667 rts . py 


12/07/99 


04:2 6p 


2,168 sigbytes.py 


12/07/99 


04:26p 


5,455 tc.py 


12/07/99 


04:26p 


7,777 ts.py 


12/07/99 


04:26p 


0 init .py 




20 File(s) 


165,312 bytes 



Directory of E:\e-speak — src 991217 \platf oriTi\ES\src\python\pyesi \abi \C 

vs 



C12/06/00 


04:33p <DIR> 




=^112/06/00 


04:33p <DIR> 




aI12/16/99 


06:22p 


744 Entries 


iJl2/16/99 


06:22p 


13 Entries. Log 


3X2/16/99 


06:22p 


48 Repository 


=-'12/16/99 


06:22p 


46 Root 


V12/I6/99 


06:22p 


846 Template 




7 File(s) 


1,697 bytes 



2:" Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi\abi\m 



-12/06/00 


04 


:33p 


<DIR> 








"^12/06/00 


04 


: 33p 


<DIR> 








12/06/00 


04 


: 33p 


<DIR> 




CVS 




12/07/99 


04 


:26p 




8 


msgOOOl. 


ser 


12/07/99 


04 


:26p 




117 


msg0002. 


ser 


12/07/99 


04 


:26p 




154 


msg0003. 


ser 


12/07/99 


04 


:26p 




53 


msg0004. 


ser 


12/07/99 


04 


:26p 




159 


msg0005. 


ser 


12/07/99 


04 


: 26p 




53 


msg0006. 


ser 


12/07/99 


04 


:26p 




194 


msg0007 . 


ser 


12/07/99 


04 


:26p 




53 


msgOOOS. 


ser 


12/07/99 


04 


:26p 




151 


msg0009. 


ser 


12/07/99 


04 


:26p 




53 


msgOOlO. 


ser 


12/07/99 


04 


:26p 




353 


msgOOll. 


ser 


12/07/99 


04 


:26p 




53 


msg0012. 


ser 


12/07/99 


04 


: 26p 




275 


msg0013 , 


ser 


12/07/99 


04 


:26p 




53 


msg0014 . 


ser 


12/07/99 


04 


:26p 




8 


msgOOlS . 


ser 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
312/07/99 
012/07/99 
yi2/07/99 
1112/07/99 
yl2/07/99 
312/07/99 
*12/07/99 
yl2/07/99 
12/07/99 
=^12/07/99 
1IL2/07/99 
a2/07/99 
BL2/07/99 
312/07/99 
a2/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 

04:26p 

04:26p 

04 :26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04 :26p 

04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 

55 File(s) 



test 

117 msgOOie.ser 
154 msg0017.ser 
53 msgOOlS.ser 
159 msg0019.ser 

53 msg0020.ser 
136 msg0021.ser 

54 msg0022.ser 
92 msg0023.ser 
54 msg0024.ser 

157 msg0025.ser 

53 msg0026.ser 

91 msg0027.ser 
57 msg0028.ser 
71 msg0029.ser 

54 msg0030.ser 
71 msg0031.ser 
54 msg0032,ser 
86 insg0033.ser 
54 msg0034.ser 

156 msg0035.ser 
54 msg0036.ser 

92 msg0037.ser 
54 msg0038.ser 

157 msg0039.ser 

53 msg0040.ser 
91 msg0041.ser 
57 msg0042.ser 
71 msg0043.ser 

54 msg0044.ser 
71 msg0045.ser 
54 msg0046.ser 
86 itisg0047 . ser 
54 nisg0048.ser 

121 msg0049.ser 
145 msg0050.ser 
75 msgOOSl.ser 

93 msg0052.ser 
4,895 bytes 



sgXCvf """^ ''^"^P^^^"^^^-^^^217\platform\ES\src\python\pyesi\abi\m 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:22p 

12/16/99 06:22p 

12/16/99 06:22p 

12/16/99 06:22p 



<DIR> 
<DIR> 



2,499 Entries 
52 Repository 
4 6 Root 
84 6 Template 
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6 File(s) 



test 
3,443 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\python\pyesi\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 

7 File(s) 



<DIR> 
<DIR> 



98 Entries 
52 Entries. Log 
44 Repository 
4 6 Root 
84 6 Template 
1,086 bytes 



Directory of E : \e-speak-src_991217\platf orra\ES\src\python\pyesi\io 



12/06/00 
12/06/00 
312/07/99 
312/07/99 
412/07/99 
J12/07/99 
yl2/06/00 
312/07/99 
^12/07/99 
U12/07/99 
12/07/99 
-12/07/99 
^12/07/99 
312/07/99 
512/07/99 
312/07/99 
312/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 



<DIR> 
<DIR> 



<DIR> 



758 array_buffer.py 
326 buf fered_output_stream.py 
691 console_output_stream.py 
7 62 console_input_stream.py 
CVS 

225 data_input_stream.py 
129 data_output_stream.py 
7 92 demultiplexer .py 
668 error_output_stream. py 
906 file.py 

843 f ile_append_stream.py 

453 f ile_input_stream.py 

695 f ile_output_stream. py 

704 f ilter_output_stream.py 

678 f ilter_input_stream. py 

055 input_stream.py 

12 6 message_copier . py 

358 message_output_stream. py 

948 message_input_stream.py 

315 multiplex_output_stream.py 

087 multiplex_input_stream.py 

477 output_stream.py 

535 queue_output_stream.py 

57 9 queue_input_stream.py 

494 router. py 

713 routing_output_stream.py 
239 routing_input_stream. py 
466 string_buf fer_output_stream.py 
64 6 string_buf f er_input_stream. py 
115 string_buffer.py 
0 init .py 
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33 File(s) 



test 
130,783 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\python\pyesi\io\CV 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File{s) 



1,724 Entries 
47 Repository 
4 6 Root 
84 6 Template 
2,663 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\net 



12/06/00 
12/06/00 
112/07/99 
a2/06/00 
^12/07/99 
^12/07/99 
112/07/99 
112/07/99 
^'12/07/99 
112/07/99 
12/07/99 
"12/07/99 
^12/07/99 



04:33p 
04 :33p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:2 6p 
04:26p 
04:26p 

13 File(s) 



<DIR> 
<DIR> 

<DIR> 



14,7 63 client_socket . py 
CVS 

9,316 http_client_stream.py 
5,148 server_socket .py 
4,848 simple_server . py 
3, 626 siinple_handler .py 
3,266 socket_output_stream.py 
3,294 socket_input_stream.py 
4,710 threaded_server . py 
2,562 threaded_handler .py 

0 init .py 

51,533 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi\net\C 

•Vs 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File(s) 



552 Entries 
48 Repository 
46 Root 

846 Template 
1,492 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\python\pyesi\util 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 



<DIR> 
<DIR> 
<DIR> 



CVS 

10,033 file_observer .py 
16,433 f ile_queue.py 
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test 

12/07/99 04:26p 8,638 log.py 

12/07/99 04:26p 3,565 threacl_pool . py 

12/07/99 04:26p 3,039 timestarap . py 

12/07/99 04:26p 6,417 url.py 

12/07/99 04:26p 0 init .py 

10 File(s) 48,125 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\python\pyesi\util\ 
CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:22p 340 Entries 

12/16/99 06:22p 49 Repository 

12/16/99 Q6:22p 46 Root 

12/16/99 06:22p 846 Template 

6 File(s) 1,281 bytes 

1 Directory of E : \e-speak:-src_991217\platf orm\ES\tutorial 

112/06/00 04:33p <DIR> 

J12/O6/OO 04:33p <DIR> 

^^12/06/00 04:33p <DIR> CVS 

^^12/07/99 04:26p 225 Makefile 

=^12/06/00 04:33p <DIR> sharebroker 

12/06/00 04:33p <DIR> usedcarsale 

' 6 File(s) 225 bytes 

Z Directory of E:\e-speak-src_991217\platform\ES\tutorial\CVS 



:i2/06/00 04:33p <DIR> 

'12/06/00 04:33p <DIR> 

12/16/99 06:22p 48 Entries 

12/16/99 06:23p 42 Entries. Log 

12/16/99 06:22p 36 Repository 

12/16/99 06:22p 46 Root 

12/16/99 06:22p 846 Template 

7 File(s) 1,018 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:26p 459 compile.bat 

12/06/00 04:33p <DIR> config 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> doc 

12/07/99 04:26p 296 Makefile 
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test 

12/07/99 04:26p 2,040 setenv 

12/07/99 04:26p 1,416 setenv.bat 

12/06/00 04:33p <DIR> src 

10 File(s) 4,211 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
onf ig 



12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04 :33p 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 



8 File{s) 



CVS 

examplel 
example2 
examples 
example 4 
examples 
0 bytes 



ii Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
lonf ig\CVS 



112/06/00 
112/06/00 
= 12/16/99 
112/16/99 
12/16/99 
'-12/16/99 
il2/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 
7 



<DIR> 
<DIR> 



File (s) 



3 Entries 
90 Entries. Log 
55 Repository 
4 6 Root 
84 6 Template 
1,040 bytes 



i Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
^^onf ig\examplel 



12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/07/99 


04 


:26p 




20 


bank.pr 


12/07/99 


04 


:26p 




261 


bankvocab . ini 


12/07/99 


04 


:26p 




1,247 


BankVocabulary . xml 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




70 


runbankvocab . bat 


12/07/99 


04 


:26p 




61 


runbankvocab . sh 


12/07/99 


04 


:26p 




110 


runvocabf inder . bat 


12/07/99 


04 


:26p 




100 


runvocabf inder . sh 



10 File{s) 1,869 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
onf ig\examplel\CVS 
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test 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:22p 366 Entries 

12/16/99 06:22p 64 Repository 

12/16/99 06:22p 46 Root 

12/16/99 06:22p 846 Template 

6 File(s) 1,322 bytes 



Directory of E: \e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
onf ig\example2 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
il2/06/00 
a2/07/99 
a2/07/99 
;l2/07/99 
•::i2/07/99 



04:33p 
04 :33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 

11 File 



<DIR> 
<DIR> 



<DIR> 



290 bank.ini 
18 bank.pr 
1,322 BankService. xml 
1,247 BankVocabulary . xml 
CVS 

65 runbankservice.bat 
90 runbankservice . sh 
107 runclient.bat 
98 runclient.sh 
3,237 bytes 



; Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
onf ig\example2\CVS 



512/06/00 
-^2/06/00 
il2/16/99 
112/16/99 
J12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s) 



407 Entries 
64 Repository 
4 6 Root 

84 6 Template 
1,363 bytes 



Directory of E: \e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
onf ig\example3 



12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/07/99 


04 


:26p 




6 


account.dat 


12/07/99 


04 


:26p 




314 


addfunds . gif 


12/07/99 


04 


:26p 




1, 097 


add_share.gif 


12/07/99 


04 


:26p 




18 


bank.pr 


12/07/99 


04 


:26p 




1, 322 


BankService . xml 


12/07/99 


04 


:26p 




1,247 


BankVocabulary . xml 


12/07/99 


04 


:26p 




1,091 


buy . gif 


12/07/99 


04 


:26p 




131 


cancelord. gif 
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260 change_dir.gif 
254 connect.gif 
330 cpwd.gif 
320 create_vb.gif 
<DIR> CVS 

131 delete.gif 
182 disconnect . gif 
275 download.gif 
110 folder.gif 
174 help. gif 
423 localserver . ini 
300 login.gif 
1,18 9 open_act.gif 
213 reconnect.gif 
72 runserver.bat 
130 runserver.sh 
1,094 sell. gif 

918 ShareBrokerVocabulary.xml 
1, 178 ShareBrokerService.xml 
95 starttrader . sh 
71 stocktrade.bat 
1,170 title.gif 

20 trader. pro 
1,335 Trader. xml 

20 traderlntf .pro 
1,253 TraderVoqabulary.xml 
1,118 TraderService.xml 
314 upload, gif 
285 watch.gif 
le(s) 18,460 bytes 

^ Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
onf ig\example3\CVS 



12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


312/07/99 


04 


:26p 


P12/07/99 


04 


: 26p 


"==112/07/99 


04 


: 26p 


^^12/07/99 


04 


:26p 


^12/07/99 


04 


:26p 


^12/07/99 


04 


: 26p 


f^l2/07/99 


04 


:26p 


=12/07/99 


04 


:26p 


.12/07/99 


04 


:26p 


^::i2/07/99 


04 


:26p 


itl2/07/99 


04 


: 2 6p 


Sfl2/07/99 


04 


: 2 6p 






39 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s) 



1,787 Entries 
64 Repository 
4 6 Root 
846 Template 
2,743 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\( 
onf ig\example4 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:26p 6 account.dat 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
312/06/00 
012/07/99 
^12/07/99 
W12/07/99 
«12/07/99 
312/07/99 
=12/07/99 
^12/07/99 
12/06/00 
:'12/07/99 
yi2/07/99 
i2/07/99 
yi2/07/99 
i2/07/99 
=42/07/99 



04:26p 

04:2 6p 

04:26p 

04:26p 

04 :26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:33p 

04:26p 

04:26p 

04:26p 

04 :26p 

04:26p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 

35 File(s) 



<DIR> 



<DIR> 
<DIR> 



<DIR> 



test 

314 
1,097 
1,444 
1,362 
1,091 
131 
260 
254 
330 
320 

131 
182 
275 
110 
174 



300 
1,189 

213 
1,094 
1,485 
1, 429 
1,430 

1,170 
1,335 
1,253 
1, 118 
314 
285 
20, 096 



addf unds . gif 
add_share. gif 
BankService.xml 
BankVocabulary . xml 
buy. gif 

cancelord.gif 
change_dir . gif 
connect.gif 
cpwd. gif 
create_vb.gif 
CVS 

delete. gif 
disconnect . gif 
download. gif 
folder . gif 
help. gif 
hostl 
host2 
login.gif 
open_act . gif 
reconnect .gif 
sell . gif 

ShareBrokerVocabulary . xml 
ShareBrokerService2 . xml 
ShareBrokerServicel . xml 
singlehost 
title. gif 
Trader. xml 

TraderVocabulary . xml 
TraderService . xml 
upload. gif 
watch, gif 
bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
onf ig\example4\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 
7 



<DIR> 
<DIR> 



File{s) 



1,453 Entries 

50 Entries. Log 
64 Repository 
46 Root 
846 Template 
2,459 bytes 



Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
onfig\example4\hostl 
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test 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/07 /99 


04 


: 26p 




141 


bank nr 


12/07/99 


04 


:26p 




22 


col 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:2 6p 




114 


runbrokerl -bat 


12/07/99 


04 


:26p 




138 


runbrokerl . sh 


12/07/99 


04 


:26p 




73 


sharebrokerl ,bat 


12/07/99 


04 


:26p 




672 


sharebrokerl . ini 


12/07/99 


04 


: 26p 




304 


sharebrokerl . pr 


12/07/99 


04 


: 26p 




158 


sharebrokerl . sh 


12/07/99 


04 


:26p 




139 


stocktrade .pr 



12 File(s) 1,761 bytes 



Directory of E: \e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
onfig\exaraple4\hostl\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s; 



448 Entries 
70 Repository 
4 6 Root 

84 5 Template 
1,410 bytes 



; Directory of E : \e-speak;-src_991217\platf orm\ES\tutorial\sharebroker\c 
ilonf ig\exarnple4\host2 



?12/06/00 
^12/06/00 
^2/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04 :26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
12 



<DIR> 
<DIR> 



<DIR> 



File (s) 



141 bank.pr 

22 co2 
CVS 

115 runbroker2.bat 
137 runbroker2 . sh 

73 sharebroker2.bat 
730 sharebroker2.ini 
302 sharebroker2 .pr 
177 sharebroker2 . sh 
139 stocktrade .pr 
1, 836 bytes 



Directory of E: \e-speak-src_991217\platf orin\ES\tutorial\sharebroker\c 
onf ig\exaitiple4 \host2 \CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
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test 

12/16/99 06:22p 448 Entries 

12/16/99 06:22p 70 Repository 

12/16/99 06:22p 46 Root 

12/16/99 06:22p 846 Template 

6 File(s) 1,410 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
onf ig\example4 \singlehost 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
112/07/99 
^2/07/99 
^12/07/99 
?12/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
12 



<DIR> 
<DIR> 

<DIR> 



File (s) 



43 bank.pr 

CVS 

549 localserver.ini 
115 runbroker2.bat 
115 runbrokerl.bat 
7 2 runserver . bat 

206 sharebroker2 . pr 

207 sharebrokerl . pr 
71 stocktrade.bat 
43 stocktrade.pr 

1,421 bytes 



\ Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
lonf ig\exaraple4\singlehost\CVS 



=12/06/00 
112/06/00 
112/16/99 
"^2/16/99 
'^12/16/99 
S12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File(s; 



456 Entries 
75 Repository 
4 6 Root 

846 Template 
1,423 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
onf ig\exam.ple5 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/07/99 


04 


:26p 




6 


account . dat 


12/07/99 


04 


:26p 




314 


addfunds .gif 


12/07/99 


04 


:26p 




1,097 


add_share. gif 


12/07/99 


04 


:26p 




43 


bank.pr 


12/07/99 


04 


:26p 




1,444 


BankService . xml 


12/07/99 


04 


:26p 




1,362 


BankVocabulary . xml 


12/07/99 


04 


:26p 




1, 091 


buy . gif 


12/07/99 


04 


:26p 




131 


cancelord.gif 


12/07/99 


04 


•.26p 




260 


change dir. gif 
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test 

12/07/99 04:26p 18 cleandb.bat 

12/07/99 04:26p 254 connect.gif 

12/07/99 04:26p 330 cpwd.gif 

12/07/99 04:26p 320 create_vb.gif 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 131 delete.gif 

12/07/99 04:26p 8,405 demoexample5.html 

12/07/99 04:26p 182 disconnect.gif 

12/07/99 04:26p 275 download.gif 

12/07/99 04:26p 110 folder.gif 

12/07/99 04:26p 174 help.gif 

12/07/99 04:26p 5,687 Imagel.gif 

12/07/99 04:26p 5,889 Imagel0.gif 

12/07/99 04:26p 17,709 Imagell.gif 

12/07/99 04:26p 13,800 Imagel2.gif 

12/07/99 04:26p 13,686 Imagel3.gif 

12/07/99 04:26p 9,041 Image2.gif 

12/07/99 04:26p 11,845 Image3.gif 

:12/07/99 04:26p 11,859 Image4.gif 

a2/07/99 04:26p 10,472 ImageS.gif 

-12/07/99 04:26p 12,712 Image6.gif 

"12/07/99 04:26p 9,852 image7.gif 

=12/07/99 04:26p 9,634 Image9.gif 

'12/07/99 04:26p 41,855 imageUUV.gif 

112/07/99 04:26p 551 localserver.ini 

12/07/99 04:26p 300 login.gif 

^12/07/99 04:26p 1,189 open_act.gif 

:i2/07/99 04:26p 5,522 README_EXAMPLE5.txt 

h2/07/99 04:26p 213 reconnect.gif 

?12/07/99 04:26p 115 runbroker2.bat 

:fl2/07/99 04:26p 115 runbrokerl.bat 

?12/07/99 04:26p 72 runserver.bat 

12/07/99 04:26p 10,163 sample . j serv. properties 

12/07/99 04:26p 1,094 sell.gif 

12/07/99 04:26p 72 sharebroker.bat 

12/07/99 04:26p 206 sharebroker2 .pr 

12/07/99 04:26p 20 shareBrokerlntf .pro 

12/07/99 04:26p 1,429 ShareBrokerService2 . xml 

12/07/99 04:26p 207 sharebrokerl .pr 

12/07/99 04:26p 1,430 ShareBrokerServicel . xml 

12/07/99 04:26p 1,485 ShareBrokerVocabulary . xml 

12/07/99 04:26p 71 stocktrade.bat 

12/07/99 04:26p 689 StockTrade.html 

12/07/99 04:26p 43 stocktrade.pr 

12/07/99 04:26p 1,170 title.gif 

12/07/99 04:26p 43 trader. pro 

12/07/99 04:26p 1,335 Trader. xml 

12/07/99 04:26p 20 traderlntf .pro 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:2 6p 
04:26p 
04:26p 
04:26p 
63 



File(s) 



test 

1,253 TraderVocabulary.xml 
1,118 TraderService.xml 
314 upload.gif 
285 watch.gif 
220,512 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
onf ig\exaniple5\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



2, 999 
64 
46 
846 



File (s] 



Entries 

Repository 

Root 

Template 



3, 955 bytes 



i Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\C 
^ VS 



'12/06/00 
^12/06/00 
■^12/16/99 
^12/16/99 
^2/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:23p 
06:22p 
06:22p 
06:22p 
7 



<DIR> 
<DIR> 



File(s) 



186 Entries 
42 Entries. Log 
48 Repository 
4 6 Root 
84 6 Template 
1,168 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\d 



:OC 



12/06/00 
12/06/00 
12/06/00 
12/07/99 



04: 33p 
04:33p 
04:33p 
04:26p 



4 File{s) 



<DIR> 
<DIR> 

<DIR> CVS 

1,806,132 ShareBrokerDocs.zip 
1,806,132 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\d 
oc\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s) 



59 Entries 
52 Repository 
46 Root 
846 Template 
1,003 bytes 
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test 



Directory of E : \e-speak-src_991217\platf orin\ES\tutorial\sharebroker\s 
rc 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


examplel 


12/06/00 


04 


: 33p 


<DIR> 


exainple2 


12/06/00 


04 


: 33p 


<DIR> 


examples 


12/06/00 


04 


: 33p 


<DIR> 


example4 


12/06/00 


04 


: 33p 


<DIR> 


examples 






8 


File(s) 


0 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
rc\CVS 



□ 12/06/00 


04:33p 


<DIR> 






012/06/00 


04:33p 


<DIR> 






M12/16/99 


06:23p 




3 


Entries 


UI12/16/99 


06:23p 




90 


Entries . Log 


UI12/16/99 


06:23p 




52 


Repository 


Q12/16/99 


06:23p 




46 


Root 


M12/16/99 


06:23p 




846 


Template 



7 File(s) 1,037 bytes 



N; Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\s 
rilrcVexamplel 



3312/06/00 


04 


: 33p 


<DIR> 




□12/06/00 


04 


: 33p 


<DIR> 




©12/07/99 


04 


:26p 




4, 723 BankVocabulary . java 


12/07/99 


04 


:26p 




4,109 BankVocabFinder . java 


12/07/99 


04 


:26p 




353 compile.bat 


12/06/00 


04 


:33p 


<DIR> 


CVS 


12/07/99 


04 


:26p 




361 Makefile 






7 File(s) 


1 


9,546 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebrok;er\s 
rc\examplel\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:23p 209 Entries 

12/16/99 06:23p 61 Repository 

12/16/99 06:23p 46 Root 

12/16/99 06:23p 846 Template 

6 File(s) 1,162 bytes 



Page 120 



test 



rc\example2 




12/06/00 


04 


:33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07 /99 


04 


:27p 


12/07 /99 


04 


:27p 


1 9 /07 /99 


04 


:27p 


1 2 /n7 /99 


04 


:27p 




0 4 


:27p 




04 


:27p 


1 9 / m / QQ 


U 4 


:27p 


12/07/99 


04 


:27p 


12/06/00 


04 


: 33p 


a 12/07/99 


04 


:27p 


;0 12/07/99 


04 


:27p 


''^^ 12/07/99 


04 


:27p 


W 12/07/99 


04 


:27p 


y 12/07/99 


04 


:27p 


1^12/07/99 


04 


:27p 






19 



<DIR> 
<DIR> 



3,326 AccountNumberGenera tor . j ava 
1,930 Address. esidl 
6,326 BankClient . java 
2,748 BankServicelntf .esidl 
3,192 BankServicelntf Finder . java 
15,603 BankServicelmpl . java 
4,094 BankService. java 
4,731 BankVocabulary . java 
1,823 Company . esidl 
491 compile.bat 
CVS 

1,007 Makefile 

2,063 OrderDetailParam. esidl 
2,275 Semaphore. java 

2.003 ShareDetailParam. esidl 
3,223 ShareDetail . java 

2.4 61 UserAccount . java 
57,296 bytes 

, Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
:;rc\example2\CVS 



<DIR> 



: 12/06/00 
: 12/06/00 
:i2/16/99 
'12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File (s) 



874 Entries 
61 Repository 
4 6 Root 

84 6 Template 
1,827 bytes 



rc\example3 




12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 



<DIR> 
<DIR> 



3,325 AccountNumberGenerator . java 

5,7 73 AddFundsGUI. java 

1,930 Address. esidl 

8,14 0 AddSharesGUI. java 

10,909 AuthorizationWindow. java 

2,783 BankServicelntf .esidl 

3,119 BankServicelntf Finder. java 
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test 




12/07/99 


04 


:27p 


14,971 


BankServicelmpl . j ava 


12/07/99 


04 


:27p 


4,083 


BankService . j ava 


12/07/99 


04 


:27p 


4, 723 


BankVocabulary . j ava 


12/07/99 


04 


:27p 


18,119 


BrokerLogic . j ava 


12/07/99 


04 


:27p 


10, 571 


BuySharesGOI . j ava 


12/07/99 


04 


:27p 


7, 170 


ChangePasswordGUI , java 


12/07/99 


04 


:27p 

XT 


1, 819 


Company . esidl 


12/07/99 


04 


:27p 


689 


coinpile • bat 


12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/07/99 


04 


:27p 


9,308 


ListAccountGUI . j ava 


12/07/99 


04 


:27p 


18, 944 


ListSharesGUI . j ava 


12/07/99 


04 


:27p 


7, 871 


TiOninf^nT n^v;^ 

-L-i w y ^ I • jcivci 


12/15/99 


04 


: OOp 


2, 405 


Makefile 


12/07/99 


04 


: 27p 


1, 901 


MatchThrpf^d ir^vs 

X. L> V_irX i. J- X X ^ ^ tJL \jL • 1 (.J, V U. 


12/07/99 


04 


:27p 


5, 656 


MessageDialog . j ava 


12/07/99 


04 


:27p 


7, 592 


OpenAccountGUI . j ava 


12/07 /99 


04 


:27p 


2, 063 


O^rdeii'Detai IPaTStn f^sidl 

\^ ^ta-* JL^ 1^ w — 1_ .^Am. X. U_ C^JL L i * _J_ 


Cil2/07/99 


04 


:27p 


3, 610 


Oi"dei"Det a i 1 *iava 

/ ^ V— A — • J_ 1^ <v U. -L. .i- • 1 V U. 


^012/07/99 


04 


:27p 


9, 686 


Sell Share sGUI i ava 


'^^2/07/99 


04 


:27p 


2,279 


1^ ^IlLCI L^l JLVw' X. ^ • J CI V CI 


^^42/07/99 


04 


:27p 


2, 650 


^ \-' -L, V _i_ \^ L./ y ^ ±. « jcivd 


UIL2/07/99 


04 


: 27p 


2, 225 


ShareBrokerTnl" "F e^^idl 


^312/07/99 


04 


:27p 


3, 255 


»— / 1 Id. -i- J_J J_ Pi. J- J- x i X. i- J- x 1 v3r J_ ■ 1 d V d 


i"^12/07/99 


04 


: 27p 


4, 600 


ShareBrokerTniDl iriva 


^112/07/99 


04 


:27p 


2, 046 


ShareDetailParam. esidl 


12/07/99 


04 


:27p 


3, 223 


ShareDetail *iava 


^^^1.2/07/99 


04 


:27p 


4 449 


^t a tI" ^hip taRto kf^i T'tT"! f^^i naTT'a 


^^42/07/99 


04 


:27p 


6, 322 


StartTradpTSprvi pp nava 

U> -U ^ J. \_4i ^ J_ V -i— \^ xL-f ■ J CJ. V CA 


^^2/07/99 


04 


:27n 


23, 802 


StockTradp iava 


^y.2/07/99 


04 


:27p 


1, 921 


TraderOuervSDec . esidl 


^=1.2/07/99 


04 


: 27p 


4,840 


TraderVocabularv . i ava 


^=42/07/99 


04 


:27p 


1, 948 


Traderlntf . esidl 


12/07/99 


04 


:27p 


2,731 


TraderService . java 


12/07/99 


04 


:27p 


4, 384 


Traderlntf Finder . java 


12/07/99 


04 


:27p 


2,979 


Trader Impl . j ava 


12/07/99 


04 


:27p 


1,969 


Transaction. esidl 


12/07/99 


04 


:27p 


2,459 


UserAccount . j ava 



46 File(s) 245,243 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
rc\ examples \CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:23p 2,389 Entries 

12/16/99 06:23p 61 Repository 

12/16/99 06:23p 46 Root 

12/16/99 G6:23p 846 Template 
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6 File(s) 



test 
3,342 bytes 



Directory of E : \e-speak-src_991217\platform\ES\tutorial\sharebroker\s 
rc\example4 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


: 27p 




3, 407 


AccountNuitiberGenerat or . i ava 


12/07 /99 


04 


: 27p 




5, 829 


?i,dd Fund sGriT "i sva 


12/07 /99 


04 


• 27d 




1, 930 


AddFf^*^^ p^^iidl 

£^\Ji\JL^ ^ I—? O < ^ O -L J- 


12/07/99 


04 


' 27d 




8, 196 


i i V_>t. 1 1 C-< J_ V ' 1^ \_l W -1. • J V V.J. 


12/01 799 


04 


: 27p 




10 880 


An1~l^AT'i 7 ,^ t* "i on Wi n Hnw "li^M^ 


1 9 707 79Q 


04 


• 27n 






ociiijs.ot;x vxv^cxiiux • tJii^xu-x 


12/07/99 


04 


• 27d 




6 0S9 


jCJCl.lXiS.OCX V-LwCXiiUXi- XIi\wlCJL > JdVCl 


1 ? 707 7 QQ 


04 


' 97n 




17 (^Q S 


D ci I i rLocx V X XXUpX . J d v d 


1 ? 707 / QQ 


04 


• 97ri 




4 ^ Q9 


DciriKDcixVXCc • JclVd. 


1 9 707 7 QQ 


04 


• 97r> 




4 7 1 R 


Ociii Js. V ov^aJJ uXcix y « J d v a. 


"'n 9 707 7QQ 


04 


' 97n 




'^'^ 1 0^ 


ox U JS-C X XiOy XL* • Jcivcl 


^^^n 9 707 /QQ 


04 


• 97n 
. Z /p 




1 0 R'^O 


DuyOiidXcJooux • J dVd 


9 707 / QQ 


Od 


* 97r^ 




S Q7 S 


L^dilCc Xwx Ciex vjU X . J dVd 


^iil 9 707 7QQ 


04 


• 97n 




7 "^P Q 

/ / O O -7 


^.--i Idiiy fci IT d t> oW L) X LiVjiu X • Jdvd 


l^h 9 707 799 


04 


• 97n 




1 R1 Q 

X , O X _7 


L^(Ji[L|JdXiy . coXUX 


Ql 9 7 07 7QQ 


04 


• 97n 

• P 




O _? X 


U vJiUp X X c . JJ d L 


Ml o 70^700 


04 








V o 


^'^■^l 9 / 07 / QQ 


04 


• 97n 




9 04 Q 


ntixptix . Jdvd 


==1 9 707 7QQ 


04 


• 97r> 




9 ?0 


XiX o Urrl-^v^w LlliL-^jUX . JctVci 


^"^12707 799 


04 


: 27p 




6, 758 


TjI s t n k "^iC^II T '1 rvr 

XJ _L O ^ J—/ d i 1 Pv O '"J KJ ^ » \ d V o. 


^I't^h 9 707 7QQ 


04 


* 97n 




7 m ft 

/ , sJ X o 


XiXoUDXiJJVtJxooUX . JdVci 


9707799 


04 


' 97n 




1 R RR9 

X (J , u u _/ 


T.n ci'hQhpr'ocir^rTT "ipttpi 

XiXo L-Oi-iCLXCoOwX • J CLv CL 


^%2/07/99 


04 


: 27p 




7, 920 


XJ W ^ -L 1 1 \J ^ • I CL V C<- 


^^12/15/99 


04 


: OOp 




2, 835 


1 Id J\, w J 1 L ^ 


^3 2 707/99 


04 


' 27d 




1 901 


LldUOllXiiJ-^CL^* J ClvCl 


12 707/99 


04 


* 97n 




S ^S7 




12/07/99 


04 


: 27p 




3,255 


Mes sacreCl lent i ava 


12/07/99 


04 


:27p 




7,618 


OpenAccountGUI . j ava 


12/07/99 


04 


:27p 




2,065 


OrderDetailParam. esidl 


12/07/99 


04 


:27p 




3, 178 


OrderDetail . java 


12/07/99 


04 


:27p 




2,054 


ReqAuthThread . j ava 


12/07/99 


04 


:27p 




7,236 


SelectBankGUI . j ava 


12/07/99 


04 


:27p 




9,890 


SellSharesGUI . j ava 


12/07/99 


04 


:27p 




2,277 


Semaphore , j ava 


12/07/99 


04 


:27p 




3,005 


ServiceDeployer . j ava 


12/07/99 


04 


:27p 




2,537 


ShareBrokerlntf . esidl 


12/07/99 


04 


:27p 




6,943 


ShareBrokerlntf Finder . j ava 


12/07/99 


04 


:27p 




6,917 


ShareBrokerlrapl . j ava 


12/07/99 


04 


:27p 




2,259 


ShareBrokerEventDistributor . jav 


a 

12/07/99 


04 


:27p 




2,048 


ShareDetailParam. esidl 
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12/07/99 


04 


:27p 


3, 226 


ShareDetail . j ava 


12/07/99 


04 


:27p 


6, 678 


StartShareBrokerService . java 


12/07/99 


04 


:27p 


e, 346 


StartTraderService . j ava 


12/07/99 


04 


:27p 


5,204 


StatusWindow . java 


12/07/99 


04 


:27p 


26, 825 


StockTrade . j ava 


12/07/99 


04 


:27p 


1, 946 


TraderQuerySpec . esidl 


12/07/99 


04 


:27p 

It 


3, 929 


Traderlntf Finder . java 


12/07/99 


04 


:27p 


2,080 


Traderlntf . esidl 


12/07/99 


04 


:27p 


3,774 


Traderlmpl . j ava 


12/07/99 


04 


:27p 


5,030 


TraderVocabulary . java 


12/07/99 


04 


:27p 


2,730 


TraderService . j ava 


12/07/99 


04 


:27p 


1,969 


Transaction. esidl 


12/07/99 


04 


:27p 


2,461 


UserAccount . j ava 



55 File(s) 321,699 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
rc\example4 \CVS 

^12/06/00 04:33p <DIR> 
'12/06/00 04:33p <DIR> 

112/16/99 06:23p 2,891 Entries 

'12/16/99 06:23p 61 Repository 

h2/16/99 06:23p 46 Root 

':i2/16/99 06:23p 846 Template 

6 File(s) 3,844 bytes 



Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
ircXexampleS 

!-12/06/00 04:33p <DIR> 

;^12/06/00 04:33p <DIR> 

12/07/99 04:27p 3,408 AccountNumberGenerator . java 

12/07/99 04 :27p 5,120 AddFundsGUI . j ava 

12/07/99 04:27p 2, 629 AddFundServlet . java 

12/07/99 04:27p 1,932 Address . esidl 

12/07/99 04:27p 3,248 AddSharesServlet . j ava 

12/07/99 04:27p 7,505 AddSharesGUI . j ava 

12/07/99 04:27p 11, 907 AuthorizationWindow. java 

12/07/99 04:27p 3,870 AuthoriseOrderServlet . java 

12/07/99 04:27p 2,783 BankServicelntf . esidl 

12/07/99 04 :27p 9,119 BankServicelntf Finder . java 

12/07/99 04:27p 17,380 BankServicelmpl . j ava 

12/07/99 04:27p 4,436 BankService . j ava 

12/07/99 04:27p 4,907 BankVocabulary . j ava 

12/07/99 04:27p 33,346 BrokerLogic. java 

12/07/99 04:27p 3,346 BuySharesServlet . j ava 

12/07/99 04:27p 9,070 BuySharesGUI . java 

12/07/99 04:27p 2,443 CancelOrderServlet . java 
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t 

12/07/99 04:27p 5 

12/07/99 04:27p 2 

12/07/99 04:27p 7 

12/07/99 04:27p 3 

12/07/99 04:27p 3 

12/07/99 04:27p 1 

12/07/99 04:27p 

12/07/99 04:27p 2 

12/06/00 04:33p <DIR> 

12/07/99 04:27p 2 

12/07/99 04:27p 1 

12/07/99 04:27p 2 

12/07/99 04:27p 2 

12/07/99 04:27p 8 

12/07/99 04:27p 2 

12/07/99 04:27p 7 

12/07/99 04:27p 2 

Q12/07/99 04:27p 2 

ajl2/07/99 04:27p 8 

M12/07/99 04:27p 3 

ijjl2/07/99 04:27p 17 

UJ12/07/99 04:27p 5 

012/07/99 04:27p 7 

1=^^12/07/99 04:27p 2 

rUl2/15/99 04:00p 3 

^^2/07/99 04:27p 1 

i-^2/07/99 04:27p 2 

i'llL2/07/99 04:27p 5 

^3L2/07/99 04:27p 4 

Wl2/07/99 04:27p 5 

C12/07/99 04:27p 2 

=3l2/07/99 04:27p 8 

12/07/99 04:27p 2 

12/07/99 04:27p 2 

12/07/99 04:27p 3 

12/07/99 04:27p 1 

12/07/99 04:27p 2 

12/07/99 04:27p 2 

12/07/99 04:27p 7 

12/07/99 04:27p 3 

12/07/99 04:27p 8 

12/07/99 04:27p 2 

12/07/99 04:27p 2 

12/07/99 04:27p 2 

12/07/99 04:27p 9 

12/07/99 04:27p 7 

12/07/99 04:27p 2 
a 



Page 



est 

,803 CancelOrderGUI. java 
,731 ChangePasswordServlet . java 
,361 ChangePasswordGUI . java 
,881 CheckSharesThread. java 
,012 CheckSharesServlet . java 
,823 Company . esidl 

689 compile. bat 
,020 Connect ionClass . java 
CVS 

,536 Encoder. java 

, 890 GetShareBrokerListServlet .java 
,049 Helper. java 

, 621 ListAccountSharesServlet . j ava 
,67 9 ListAccountGUI . java 
, 571 ListAccountBalanceServlet .java 
,471 ListBanksGUI. java 
,588 ListBanksServlet . java 
,775 ListBrokersServlet . java 
,108 ListBrokersGUI . java 
,201 ListSharesServlet . java 
,095 ListSharesGUI. java 
,735 ListShareBrokersGUI . java 
521 LoginGUI . j ava 
501 LoginServlet . j ava 
091 Makefile 
901 MatchThread. java 
122 MessageDump. java 
678 MessageDialog. java 
084 MessageClient . java 
908 Message. java 
662 OpenAccountServlet . java 
990 OpenAccountGUI. java 
106 OrderCollect ion. java 
064 OrderDetailParam. esidl 
182 OrderDetail . java 
891 QuerySpec. esidl 
659 QuerySpec. java 
054 ReqAuthThread. java 
129 SelectBankGUI. java 
215 SellSharesServlet. java 
402 SellSharesGUI. java 
275 Semaphore . java 
598 ServiceDeployer . java 
535 ShareBrokerlntf. esidl 
723 ShareBrokerlntfFinder . java 
299 ShareBrokerlmpl . java 
261 ShareBrokerEventDistributor . jav 

125 



12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:27p 
04:27p 
04:27p 
G4:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 

81 File{s) 



test 

2,045 ShareDetailParam.esidl 

3,565 ShareDetail . java 

6,741 StartShareBrokerService . java 

5, 365 StartTraderServiceServlet . java 

3,254 StartTraderService. java 

4,708 StatusWindow. java 

29,153 StockTrade. java 

1,945 TraderQuerySpec.esidl 

5,059 TraderVocabulary. java 

2,078 Traderlntf .esidl 

2,729 TraderService. java 

3,944 Traderlntf Finder. java 

3,614 Traderlmpl . java 

1,986 Transaction. java 

2,545 UserAccount . java 
403, 670 bytes 



J Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\s 
|r c \ e xaitip 1 e 5 \ C VS 



1I12/O6/OO 
sJl2/06/00 
312/16/99 
=^12/16/99 
II12/I6/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File(s) 



4,413 Entries 
61 Repository 
4 6 Root 
84 6 Template 
5,366 bytes 



Directory of E : \e-speak-src_991217\platf ormXESXtutorialVusedcarsale 



-:|L2/06/00 


04 


:33p 


<DIR> 






=12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:27p 




1,208 


Carsales . ini 


12/06/00 


04 


:33p 


<DIR> 




conf ig 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/06/00 


04 


: 33p 


<DIR> 




html 


12/07/99 


04 


:27p 




229 


Makefile 


12/07/99 


04 


:27p 




5, 938 


README 


12/07/99 


04 


:27p 




126 


runcore.bat 


12/07/99 


04 


:27p 




472 


runservers . bat 


12/07/99 


04 


:27p 




5, 923 


sample . zone . properties 


12/07/99 


04 


:27p 




10, 177 


sample . j serv. properties 


12/06/00 


04 


: 33p 


<DIR> 




servlets 


12/07/99 


04 


:27p 




2,892 


setenv 


12/07/99 


04 


:27p 




2, 152 


setenv.bat 


12/07/99 


04 


:27p 




6 


Slides. ppt 


12/06/00 


04 


: 33p 


<DIR> 




src 



17 File(s) 



29,123 bytes 
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Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\usedcarsale\c 



on "F 1 rf 












1 2/06/00 


04 


• 33d 

• »J 


<DIR> 






1 ? /n^/on 


04 


■ ,j 


<nTR> 






12/07/99 


04 


:27p 




117 


Ruvprl Dr 


12/07/99 


04 


■ 27d 




97 


Buver2 

j-j' V-* y ^ X. • 


12/01 /99 


04 


: 27p 




73 


CarAd or 




04 






i U *J 


^^di- Di. vJ i. Z. » pi- 


1 0 /Ol /QQ 


04 


• ?7o 




JU ^ ^ 


^*^ T"R T'O Vf^* T~ T 'Ciir 
^w- CL i_ O i. W fvC J_ X • p J_ 


1 9 /Ol /99 


04 


• ?7n 




97 




12/07/99 


04 


:27p 




22 


CO . MYCO 


12/06/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:27p 




1,129 


input .ptml 


12/07/99 


04 


:27p 




129 


Payment .pr 


12/07/99 


04 


:27p 




737 


response. ptml 


1 1112/07/99 


04 


:27p 




99 


Sellerl .pr 


ifil2/07/99 


04 


:27p 




97 


Seller2 .pr 


■^,112/07/99 


04 


:27p 




141 


SendMail Server 



16 File(s) 



2,900 bytes 



i-l Directory of E:\e-speak-src_991217\platforin\ES\tutorial\usedcarsale\c 
h^nfig\CVS 



^ 12/06/00 
1=^2/06/00 
11112/16/99 
a2/16/99 
W2/16/99 
a2/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 

6 File(s; 



<DIR> 
<DIR> 



621 Entries 
55 Repository 
4 6 Root 

846 Template 
1,568 bytes 



Directory of E: \e-speak-src_991217\platf orni\ES\tutorial\usedcarsale\C 
VS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
06:23p 

7 File(s) 



<DIR> 
<DIR> 



495 Entries 
61 Entries. Log 
48 Repository 
4 6 Root 

84 6 Template 
1,496 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\usedcarsale\h 
tml 
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test 



12/06/00 


04 


:33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 

XT 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 

It 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


512/07/99 


04 


:27p 

IT 


iC12/07/99 


04 


:27p 


ai2/07/99 


04 


:27p 


UI12/07/99 


04 


:27p 


iAll2/07/99 


04 


:27p 


□12/07/99 


04 


:27p 


W2/07/99 


04 


:27p 


iUl2/07/99 


04 


:27p 


n 12/07/99 


04 


:27p 



<DIR> 
<DIR> 



<DIR> 
<DIR> 



26 File(s) 



5, 634 
1,828 
2,456 
2,456 
1,757 
2,660 
2,660 
1,878 
1,876 
3,469 
3,469 



AdvertiseToSell . html 
BuyerFirstScreen. html 
BuyerLogin2 . html 
BuyerLoginl . html 
buyerops . html 
BuyerRegister2 . html 
BuyerRegisterl . html 
Carbrok:erFirstScreen2 . html 
CarbrokerFirstScreenl . html 
choice2 .html 
choicel . html 
CVS 

images 

14,010 newcarsales.html 
1,824 SellerDetails.html 
1,888 SearchForSellers.html 
2,456 SellerLoginl.html 
1,829 SellerFirstScreen.html 
2,661 SellerRegister2.html 
2,661 SellerRegisterl.html 
1,661 sellerops.html 
2,458 SellerLogin2.html 
1,343 thanks.html 

20,513 webdemo.html 
83,447 bytes 



□ Directory of E:\e-speak-src_991217\platform\ES\tutorial\usedcarsale\h 
?3tml\CVS 



a2/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
06:23p 

7 File(s) 



<DIR> 
<DIR> 



1,205 Entries 

16 Entries. Log 
53 Repository 
4 6 Root 
84 6 Template 
2,166 bytes 



Directory of E: \e-speak-src_991217\platform\ES\tutorial\usedcarsale\h 
tml\ images 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:27p 
04:27p 
04:27p 



<DIR> 
<DIR> 



13,761 buy.jpg 
11,004 car3_anm.gif 
19,273 carbroker.jpg 
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12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
^2/07/99 
il2/07/99 



04:33p 

04:27p 

04:27p 

04 :27p 

04 :27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04 :27p 

04:27p 

04:27p 

24 File(s) 



<DIR> 



test 

52 
2,578 
82,264 
971 
971 
98,743 
160,012 
161,302 
110,035 
123,161 
128, 175 
131,157 
141,087 
157,932 
161,582 
159,451 
7,986 
398 
1, 671,895 



CVS 

espeak. JPG 
happy.gif 
interact . jpg 
left-hand. gif 
right-hand. gif 
si. jpg 
slO .jpg 
sll .jpg 
s2.jpg 
s3 . jpg 
s4.jpg 
s5 . jpg 
s6. jpg 
s7.jpg 
s8.jpg 
s9.jpg 
seller. jpg 
visal_60x38_a . gif 
■ bytes 



W12/06/00 
12/06/00 
=12/16/99 
^12/16/99 
312/16/99 
%2/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File (s) 



965 Entries 
60 Repository 
4 6 Root 

846 Template 
1,917 bytes 



ervlets°''^ E:\e-speak-src_991217\platform\ES\tutorial\usedcarsale\. 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/15/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04 :33p 
04:33p 
04:27p 
04:33p 
04:00p 
04:27p 
04:27p 
04:27p 
04:27p 
9 



<DIR> 
<DIR> 

<DIR> 



File (s) 



880 compile.bat 
CVS 

663 Makefile 
4,158 Register. java 
38,178 RunCarSellerClient . java 
46,235 RunCarBuyerClient . java 
13,415 RunCarBrokerService. java 
103,529 bytes 



erv^Jts\C^S°^ ^= \^-^P^^'^-=^<=_991217\platform\ES\tutorial\usedcarsale\s 
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test 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File (s) 



326 Entries 
57 Repository 
46 Root 

84 6 Template 
1,275 bytes 



Directory of E; \e-speak-src_991217\platforin\ES\tutorial\usedcarsale\s 
rc 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
112/07/99 
; 12/07/99 
?12/07/99 
^12/07/99 
=12/07/99 
112/06/00 
12/07/99 
■=12/15/99 
il2/07/99 
^12/07/99 
J12/07/99 
h2/07/99 
'12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04 :27p 
04:27p 
04:33p 
04:27p 
04:00p 
04:27p 
04:27p 
04:27p 
04 :27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 

29 File(s) 



<DIR> 
<DIR> 



<DIR> 



11,086 BrokerManager . java 
2,088 Buyerlnfo.esidl 

19,355 BuyerManager . java 
2,416 CarAdlntf .esidl 

13,041 CarAdlmpl. java 
2 , 902 CarBrokerlntf . esidl 

15,108 CarBrokerlitipl. java 
2,416 CarDetails. esidl 
1,556 compile.bat 
2,929 Constants , java 
CVS 

2,137 DealDetails . esidl 

2,078 Makefile 

2,094 Payment Intf .esidl 

6,501 PaymentServer . j ava 

3,322 Payment Impl . java 

2,071 PTML. esidl 

2,152 Sellerlntf .esidl 

21,491 SellerManager . java 
2,190 Sellerlnfo. esidl 
8,164 Sellerlmpl. java 
2,259 SendMaillntf .esidl 
4,043 SendMailServer . java 
3,714 SendMaillmpl . java 
6,565 ServiceStopper . java 
2,367 Stoppable. java 
3,580 Util.java 

147,625 bytes 



Directory of E; \e-speak-src_991217\platform\ES\tutorial\usedcarsale\s 
rc\CVS 



12/06/00 
12/06/00 



04:33p 
04:33p 



<DIR> 
<DIR> 
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12/1S/99 06:23p 
12/15/99 06:23p 
12/16/99 06:23p 
12/15/99 05:23p 

6 File(s) 

Total Files Listed: 
4189 File(s) 



test 

1,369 Entries 
52 Repository 
4 6 Root 
84 5 Template 
2,313 bytes 

18,116,673 bytes 

0 bytes free 
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Chapter 1 introduction 



This document specifies the e-speak architecture. It defines the abstractions 
presented by the system and the components that implement those abstractions, 
and shows how the components interact to create useful services. The following 
companion documents are also available: 

• E-speak Programmers Guide defines the interface for e-speak programmers 
and system developers building e-speak-enabled applications. 

• E-speak Installation Gaic/e shows how to install e-speak and how to run some 
simple applications. 

• E-speak Contributed Services describes several sample applications included 
with the distributed software. 

• E-speak Tools Documentation shows how to use tools provided for analyzing 
the system. 



Vision 

Computing with e-speak is a paradigm switch, aiming to bring a "just plug in, use the 
services you need, and pay per usage** model to computation, as opposed to the 
"install on your machine and pay per installation" model of computation prevalent 
today. E-speak is the infrastructure that realizes the vision of such a model. Instead 
of thinking of computing as some hardware you buy and the software you install on 
it, e-speak encourages you to think of computing as a set of services you access as 
needed. 
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Goals 



Introduction 



The reality of computing today is that it is much more complex than a utility like the 
electric or water system. An immense variety of computing resources exists, both 
in type and in power, and a newer, faster, cheaper, or better resource is probably 
invented by the time you finish reading this sentence. This dynamism is a 
formidable challenge to interoperability. 

At the same time, most of these resources are being connected to each other on a 
range of scales, from homes to companies to the entire globe. The hardware 
necessary to support such a computational utility is already available and getting 
better by the day. On the software front, though the Web has essentially achieved 
the status of a data utility, actual computation remains mainly confined to 
individual machines and operating systems. 

E-speak enables a computation utility by interposing on and mediating every 
resource access in a process called virtualization. This broad abstraction yields a 
model where machines, ranging from a supercomputer to a beeper, can be looked 
at uniformly and can cooperate to provide and use services. 



Goals 

E-speak aims at enabling ubiquitous services over the network- malting existing 
resources (e.g., files, printers, Java objects, or legacy applications) available as 
services, as well as lowering the barriers to providers of new services. The 
infrastructure's goal is to provide the basic building blocks for service creation, 
including: 

• Secure access to resources and service 

• Usage monitoring, billing, and access control 

• Advertising and discovery of new services 

• Mechanisms for negotiation to find the "best" service 

• Independence of operating system, language, and device 

• Ability to support large enterprise-wide, intra-enterprise, and global 
deployments 
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Architectural Philosophy 

This document specifies the e-speak architecture. There are four key concepts: 

• Resource: Any computational service, such as a file or a banking service, that is 
virtualized by e-speak. 

• Client: An active entity that requests access to Resources or responds to such 
requests. 

• Protection domain: The part of the e-speak environment visible to a Client. 

• Logical machine: An active entity that performs the operations needed to 
implement e-speak. 

E-speak is based on the following: 

• All Resource access is mediated; e-speak sees all Resource requests. 

• All Resource access is virtualized; e-speak maps between virtual and actual 
references. 

• Names for Resources are shared by convention only; e-speak keeps a separate 
name space for each Client. 

This document does not specify anj^hing outside of the e-speak architecture. 
However, some implementation details are included to show some points. These 
sections are marked "informational." 



Environment 

E'Speak is designed to work in a hostile, networked environment such as the 
Internet. It isolates service providers and their clients from an inherently insecure 
medium while allowing them to negotiate safely, form contracts, and exchange 
confidential information and services without fear of attack. 
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Introduction 



Intended Audience 

This E-speak Architecture Specification describes the lower-level interfaces of e- 
speak for: 

• Implementors of Client libraries to provide a higher level of abstraction for e- 
speak 

• Implementors of utilities and tools to manage and manipulate e-speak 

• Implementors of e-speak emulation routines that are used in the run-time 
environment for legacy applications 

• Implementors of extensions to existing services and resources used by Clients 

• System administrators who implement policies for security and resource lookup 

• Those designing and building their own implementations of e-speak 

Structure 

This specification consists of the following major sections, in the order listed: 

• An overview of the e-speak architecture 

• A description of the data structures used by e-speak to describe Resources- 
Resource metadata 

• The interfaces to the e-speak platform that are exposed as " Core-managed 
Resources** 

• A description of Vocabularies, the mechanism for processing Resource 
descriptions to discover and match Resources to the Client's description of 
Resources needed 

• The e-speak mechanisms used for access control 

• The e-speak communication architecture 

• The exceptions that can be generated by the e-speak platform 
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• The e-speak Event Service 

• The e-speak management architecture 

• The e-speak Respository used for storing Resource metadata (informational) 

• A description of how localization is implemented (informational) 

• A glossary of terms 

• A brief description of probable future extensions to e-speak (informational) 



Conventions 

There are several document conventions worth noting: 

• New terms are introduced in the document flow with italics. 

• Programmatically visible architectural abstractions are vmtten with the first 
letter of each word capitalized, such as Protection Domain. 

• Logical names, method names, and other programmatic labels are written in 
Courier font. 

• Even though e-speak is independent of the programming language, the 
specification uses Java syntax. 

• Sections describing material outside of the architecture are shown vdth the 
word * Informational" in the chapter or section title. 
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Chapter 2 Architecture Overview 



All system functionality and e-speak abstractions build on top of one single first- 
class entity in the e-speak architecture- a Resource. A Resource is a uniform 
description of active entities such as a service or passive entities such as hardware 
devices. Unlike most platforms, e-speak deals only with data about Resources, 
metadata, and not Resource-specific semantics. Thus, a file Resource within the e- 
speak environment is simply a description of the attributes of the file and how it can 
be accessed. The e-speak platform does not access the file directly. A Resource- 
specific handler that is attached to the e-speak platform receives messages from e- 
speak and directly accesses the Resource. 

Access to e-speak is provided by the e-speak Service Interface (ESI). Client 
applications and Resource Handlers are linked with a library that provides this 
interface. The library communicates with the e-speak platform using the Session 
Layer Security Protocol i^lS^ . The e-speak platform mediates all Resource access. 
Every access to a Resource through e-speak involves two different sets of 
manipulations: 

1 The e-speak platform uses its Resource descriptions for dynamic discovery of 
the most appropriate Resource, transparent access to remote Resources, and 
sending Events to management tools. 

2 The Resource-specific handler directly accesses the Resource such as reading 
the disk blocks for a file, 

E-speak treats all Resource accesses in exactly the same maimer. This mediated yet 
uniform access is the design principle that allows the e-speak environment to 
accommodate any kind of Resource type flexibly, even Resources dynamically 
defined after the e-speak system has started. 
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Architecture Overview 



The e-speak platform maintains an environment for each of its Clients, called a 
Protection Domain. A Protection Domain is analogous to a "home directory" in an 
operating system. It contains bindings to Resources created by the Client and e- 
speak keeps track of memory usage due to these bindings. 

A single instance of the e-speak platform is called a Logical Machine, Figure 1 
shows a single Logical Machine. There may be multiple Logical Machines on a single 
physical machine, or the components of a Logical Machine may be distributed 
across multiple machines. Logical Machines are independent entities that 
communicate using the Session Layer Security Protocol as shown in Figure 2. 



Client 



Resource 
Handler 



Logical 
Machine 




Figure 1 Resource access in e-speak 
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Figure 2 Communicating e-speak logical machines 



Each e-speak Logical Machine has a single instance of the e-speak Core. All 
Resource access is through the Core that uses the Resource metadata to mediate 
and control each access. To access a Resource, a Client sends a message to the e- 
speak Core naming the Resource. The e-speak Core uses the Resource metadata to 
locate the Resource Handler and forwards the message to the Resource Handler 
that, in turn, physically accesses the Resource. 

Although Figure 1 shows the Resource Handler being outside the Core (i.e., in a 
separate process), the handler for some Resources is the Core itself; these 
Resources are inside the Core and are called Core-managed Resources. E-speak 
Clients can manage and interact with the Core by sending messages to these 
Resources. For example, one kind of Core-managed Resource is a Resource 
Factovj. When a Client wants to create a new Resource instance, it sends a message 
to the Resource Factory to register the Resource metadata with e-speak. 

Logically, there are three categories of Resource access; 
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Architecture Overview 



• A service provider can choose to register the metadata of its service. The e- 
speak Resource model describes the contents of this metadata. 

• A Ghent or service provider may look up a service and bind to it, prior to 
accessing it. The search rules and the information model for descriptions are 
defined by the registered Resource metadata. 

• A Client or service provider may invoke an entry point on a service. The previous 
two are special cases of this last one, because they may be considered as 
invocations on entry points of Core-managed services. 

In all cases, the mediating e-speak Cores perform name resolution and generate 
monitoring information as part of this access. 

Clients who wish to access a service do so through the e-speak Core, which uses the 
appropriate Resource metadata to route the Client request to the correct handler, 
after having performed all desired name translation, and other e-speak 
functionality. 

The following sections outline the various components of the e-speak architecture 
and describe the steps in a service access. 



Mediation Architecture 

Following are the main components of the mediation architecture: 

• A set of Core-managed Resources inside the e-speak Core. The Core-managed 
services present the system functionality for managing the e-speak platform, 
including creating Protection Domains and their contents and managing 
Resource metadata. 

• A Repository containing Resource metadata available to Clients of the Logical 
Machine. These are the metadata that the Core evaluates during any service 
access. 

• A routing engine that routes all service access messages based on the contents 
of the metadata of Resources referred to in the parameters of the message. The 
implications of this are discussed below. 
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Resource Model 



Resource Model 

The Resource is a representation of an e-servi'ce within e-speak. Service providers 
register the metadata of their services (e-speak Resources) with the Core. This 
includes the information depicted in Table 1. 



Table 1 Resource Model 



Description 


An attribute-based specification of the Resource 


Vocabulary 


The definition of the attributes and their types used in 
descriptions and lookups 


Resource Handler Mailbox 


The process/thread/task that handles the Resource 


Contract 


Denotes the Application Programming interface (API) 
supported by the provider, including version and 
similar information 


Resource mask, owner 
public key and service ID 


Access control Information 


Private Resource-specific 
data 


Data Important to the provider of the Resource, such 
as the provider's internal name for the Resource. Not 
interpreted by e-speak. 


Public Resource-specific 
data 


Data important to the user of the Resource, such as a 
stub for invoking methods. Not interpreted by e- 
speak. 



The Resource metadata is maintained in the mediating Core s Repository. All 
functionality presented through the Core must have metadata within the Core, This 
is true even for the functionality provided by the Core itself 
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Architecture Overview 



Metadata System 

The e-speak metadata system is based on the following architectural and semantic 
entities: 

• Vocabularies are created as first-class Core-managed services. Thus, the model 
includes a metalanguage for creating a whole range of vocabularies with which 
to describe services, much like that of XML. XML document type definitions 
(DTDs) can be handled through the e-speak Vocabulary Builder. 

The representation of vocabularies as Resources ensures that they can be 
dynamically discovered and protected from illegal access, and that access to 
them is mediated as required, like any other service in e-speak. In the e-speak 
architecture, a created Vocabulary decides the validity of an attribute descrip- 
tion provided by a registering service provider. 

The Core-managed Vocabulary service also includes a matching engine that is 
used to match Resource descriptions available in the Repository with search 
requirements of Clients of e-speak. 

• Attribute-based service descriptions are used by service providers as part of 
service registration. These attribute descriptions are sets of name-value pairs in 
a specific vocabulary. The Vocabulary is either one that the service provider 
previously created (using the Vocabulary Builder) or discovered through the 
discovery facilities provided by the e-speak Core services. 

• Search Recipes are objects that hold a Client s recipe for discovering a 
Resource. The Core uses this to process the Resource discovery request. A 
Search Recipe specifies what Resources the Client is looking for, how the 
lookup should be done, and what should be done if multiple matches occur. The 
Search Recipe contains the predicates and a Repository view mechanism with 
which to constrain the search. A search predicate is constructed with a 
Vocabulary and a constraint string expressed in that Vocabulary. The predicate 
is expressed in a form based on the Object Management Group trader services 
constraint grammar. 

• The operational realization of the metadata system includes support for 
including arbitrary advertising services as part of extended searches, arbiters to 
optimize matches found through the Core Repositories, and integration of 
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Naming Model 



Vocabulary translation services with the lookup/discovery process. Advertising 
services provide scalability to service lookup in e-speak by supplying a means to 
find Resources not registered in the local Repository. Arbiters are used to affect 
special purpose optimizations such as handling miUtiple hits in lookups. 
Translation services can be integrated with Core-managed Vocabulary services 
or created as external services, thus allowing for translation between 
Vocabularies. 



Naming Model 

The e-speak naming system is based on the following principles. 

• E-speak Names are Universal Resource Locators (URLs) . 

• Name spaces are maintained in container Core-managed Resources called 
Name Frames. Name Frames can themselves contain other Name Frames, so 
each e-speak Core has a hierarchy of Name Frames beginning from its roof 
Name Frame. By default, when the Client specifies the name of a service, the e- 
speak Core, starting with its root Name Frame, finds mapping between the name 
and a name unique to this Core, In addition, a client can specify a name 
beginning in the root Name Frame of another e-speak Core, by specifying the 
host in the e-speak Name. 

• The e-speak Core provides the only valid reference to a service as a name in the 
Client-specific name space. This is like a virtual address of a service. The 
physical address of a service, the Core s name, is not a valid Client reference for 
a service. 

• There are two ways for a Client to get a name for a service. First, another Client, 
application, or service provider can pass it the name. Second, a Client may 
obtain a per-Client name through a bind call that requires a Search Recipe as a 
parameter. The e-speak system (Core and Client libraries) looks up the name in 
local Repositories, known remote Repositories, and if necessary a global 
advertising service to locate the appropriate service and create a binding for the 
Client in its name space. 
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• Bindings in e-speak are objects that capture an algorithm. At their simplest, 
bindings may capture a Search Recipe. These bindings may be resolved and 
frozen to a specific Core name or names, resolved and cached, or simply 
resolved on each access. This gives the e-speak system an active naming model. 
Even when resolved, a Client reference may be bound to multiple Core names, 
which may be arbitrated prior to service access. This may be done by using a 
Client-specified arbitration service that picks one particular service from a list 
of services represented in a binding. 



Access Control 

E-speak security is based on a Public Key Infrastructure (PKI) . Specifically it uses 
the Simple Public Key Infrastructure (SPKI) developed v^athin the Internet 
Engineering Task Force. 

All entities in e-speak (Resources and Cores) are identified by public keys. To 
authenticate an entity, we verify that it knows the private key corresponding to the 
given public key. No entity should ever intentionally share its private key or give 
anybody access to the private key. 

Any entity can create a key-pair. Provided the private key is kept secret, the key-pair 
is unique to that entity. However, having a key-pair gives you no power in the 
system. It is necessary also to have certificates stating access rights issued to your 
public key. 

In e-speak, access rights are stated in attribute certificates. So as well as the 
conventional use of certificates to bind a name to a public key (e.g. X.509), we also 
use certificates to bind access rights to public keys. This helps to have online access 
control databases or access control lists. 

To decide whether to honor an incoming request a Resource Handler must decide 
if it has a certificate (or certificates) granting access rights for the request. If it finds 
such a certificate, it must verify that the sender of the request knows the private key 
corresponding to the public key in the certificate to which the access rights have 
been given (formally this is the subject of the certificate). It does this by a 
cryptographic protocol that is described in Chapter 6, "Communication". 
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Finally before honoring the request, the Resource Handler must verify that it trusts 
whoever issued the certificate. It does this by verifying that the certificate has been 
signed by an entity that it trusts. Resource Handlers do not trust all certificate 
issuer s equally, A Resource Handler can choose whether to trust a given certificate 
issuer and may restrict what access rights a given certificate issuer can issue. 



Communication 

E-speak uses a mailbox metaphor to describe the interactions between Clients and 
the Core. This metaphor does not imply that any actual messaging is required, only 
that the interfaces are defined in terms of mailboxes. Mailboxes consist of two 
forms: an Outbox and a Core-managed Resource called an Inbox. 

When a Client wants to \ise a Resource, it constructs a message consisting of a 
message header and a payload and inserts the message in the Client's Outbox. The 
Outbox is connected to the Core, which processes the information in the message 
header. If there is no error, the Core extracts Resource specific metadata and 
security information from its Repository and inserts this in the message before 
forwarding the message to the designated Inbox. The Resource Handler reads the 
message header and the inserted payload to determine how to deal with the request. 

The Resource specific metadata and security information inserted by the Core into 
a message can be used by the Resource Handler to determine how to process the 
message. 

As each message is routed, the e-speak Core may generate events for logging and 
monitoring. 

E-speak uses peer-to-peer communication. The Core has no concept of a reply 
message. If the Resource Handler needs to return a value to the Client, it must 
specify a Resource listing an Inbox connected to the Client in the handler field of its 
metadata. Hence, in replying to a message, the Resource Handler changes roles with 
the Client. 
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Session Layer Security Protocol 

All messages exchanged between e-speak Cores and between e-speak Cores and 
Clients use the Session Layer Security protocol. This provides secure message 
passing between entities as well as unprotected message exchanges. Applications 
can choose whether to use secure message passing or not. 

Session Layer Security protocol is designed to support e-speak mediation. E-speak 
mediation requires e-speak to modify certain parts of the message so that the 
message can be routed between endpoints and means there is no TCP connection 
between the endpoints. These requirements mean that existing protocols such as 
SSL (Secure Sockets Layer) or TLS (Transport Layer Security) are not suitable for 
end to end security in e-speak. 

Session Layer Security protocol allows multiple secure sessions to be multiplexed 
over a single TCP connection. This means that two e-speak Cores can be connected 
via a single TCP connection with many Clients and have many different secure 
sessions to different e-speak Resources. 

Session Layer Security protocol also supports tunnelling. Dtiring firewall traversal 
we might want the firewall to control the client access rights to the internal LAN for 
every packet. However, we might not want the firewall to see all the traffic in clear 
(therefore, losing the end-to-end security property). With Session Layer Security 
protocol we can nest a secure session inside anotiier one, possibly with different 
end points, allowing us to achieve both goals simultaneously. 

Session Layer Security protocol is designed to support SPKI for access control It 
performs the negotiation of access rights that need to be proven represented by 
multiple SPKI certificates. 

Session Layer Security supports the following encoding types for messages: 

• CLEAR_DATA: The message is not encrypted or protected against 
modification. 

• PROTECTED^DATA: The message is not encrypted but it is protected 
against modification. 

• SECURE_DATA: The message is encrypted and protected against 
modification. 
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Session Layer Security has been designed to be independent of transport. However, 
for interoperability between e-spealt Cores and interoperability between e-speak 
Cores and Clients, direct implementation over TCP is assumed. Other 
implementations are possible, including passing SLS messages over HTTP, or 
through shared memory. 

Core to Core Communication 

Communication between e-speak Cores uses the Session Layer Security protocol. 
Two core-managed Resources are used for remote communication between e- 
speak cores: the Connection Manager (for connection management) and Remote 
Resource Manager (for management of remote resource metadata). 

The Connection Manager sets up the initial connection, manages it and closes it 
down when it is no longer needed. It requires the host name (or IP address) and port 
of the remote e-speak Core to set up a remote connection. The Connection Manager 
has a well known name: es://<server>/CORE/ConnectionManager. So given the host 
and port number (i.e. the <serve> part) a Connection Manager can negotiate with 
the remote Connection Manager to establish a connection between the two e-speak 
Cores. Once the two Connection Managers have established a connection, Cores 
exchange Resources with each other using their Remote Resource Managers for 
Resource export and import. 

The Remote Resource Manager is responsible for managing metadata: importing 
and exporting resources from the remote e-speak core. The Remote Resource 
Manager on any given e-speak core is: es://<server>/CORE/ 
RemoteResourceManager. So given that two Connection Managers have 
established a connection between two e-speak Cores, the Remote Resource 
Managers can communicate with each other to exchange Resources. 

All resources can be exported by reference, in which case a copy of the metadata of 
the Resource is sent to the remote core. In addition certain Core-managed 
Resources can be exported by value, in which case a copy of the Resource is sent 
to the remote e-speak Core. 

Resource import and export serves a number of purposes in e-speak. 

• Resource discovery is made more efficient for local Clients, because a copy 
of the metadata is available locally. 
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• The lookup mechanism requires that a vocabulary is available locally for 
both Resource registration and lookup in that vocabulary. Using Resource 
export, a vocabulary can be defined once and exported to wherever it is 
needed. 

• Name Frames can be defined containing a set of useful bindings (akin to an 
environment for a Client). Using Resource export, these Name Frames can 
be made available locally wherever a Client needs them. This can be 
particularly useful for mobile clients. 



An End-to-End Example 

When the Client on Logical Machine A sends a message to its Core for a Resource 
on Logical Machine B, the following steps take place (see Figure 3): 

1 The Client constructs and Session Layer Security message setting the "to" 
address to the Name of the Remote Resource (e.g. es://<host_for_core3>/ 
resource/foo). The from address is set to the Name of the Client (e.g. es : // 
<host_f or__core_A>/client /bar). This message is sent using TCP to Core 
A, where it is placed in the Client s outbox. 

2 A message handling thread in Core A, picks up the message and sends it to Core 
As router. Core As router determines that the message is for Core B. It checks 
that it has a connection with Core B and forwards the message to the relevant 
inbox. 

3 A message handling thread on Core A picks the message up from the inbox and 
transmits it to Core B (via a TCP connection) where it is placed in the outbox for 
incoming messages from Core A. 

4 The router on Core B resolves the Name for the "to address" in its root Name 
Frame. The resolved name is a binding to the Resource metadata. 

5 Core B s router retrieves the Resource s metadata. This tells it to which inbox to 
send the message. It also extracts the Private Resource Specific data and various 
security information that is used by the Resource Handler to process the 
message. 
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The E-speak Service Interface (Informational) 



6 A message handUng thread picks the message up from the inbox and sends it to 
the Resource Handler through a TCP connection. 

7 Any communication between the Resource Handler and the physical Resource 
is outside of the control of the e-speak Core. 



Logical Machine A 



THesouTce 






Handler 




Resource 


i 


i 








Logical Machine B 



OB = Outbox 
IB - Inbox 



Figure 3 Distributed e-speak 



The processing for any return message is similar, except the roles of the respective 
e-spealc Cores are reversed (recall e-speak is asynchronous - the Core does not 
distinguish between request and reply messages when routing them). 



The E-speak Service Interface (Informational) 

An e-speak Client is an application running in its own address space that was 
written using an e-speak Service Interface (ESI). There is one ESI for each 
programming language supported. An example ESI is shown in Chapter 1 of the E- 



Developer Release X.03.03.00, September 2000 



19 



E-speak Services 



Architecture Overview 



speak Pro^ammefs Guide, This provides a rich environment offering rapid, 
secure-service development, deployment, and management in a heterogeneous 
networked environment. 



E-speak Services 

E-speak has the following services: Event, management and advertising. 

• The Event Service allows applications to collaborate by publishing Events and 
subscribing to Event distributors. The e-speak Core uses the Event Service to 
publish Events to the management service, 

• The Management Services manage interconnecting sets of e-speak Cores, 
managing the distribution of metadata, and e-services registered as e-speak 
Resources. 

• The Advertising Service is used for distributed Resource discovery in large-scale 
environments. 



Standards 

The e-speak platform builds upon and uses existing industry standards wherever 
possible. In some cases, integration with industry standards is under way or 
planned. The specific areas of integration include: 

• Database access- The persistent back-end for the Repository uses Java 
Database Connectivity, thus making it possible to send Repository queries to 
almost any relational database. 

• Advertising services- The Advertising Service back-end is provided by 
Lightweight Directory Access Protocol. 

• Transport protocols: The ESIP messaging stack supports pluggable transports. 
TCP/IP, IrDA, WAP, and HTTP are all candidate transports. 
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• Service description: E-speak supports multiple different Vocabularies, including 
forthcoming support for XML and X,500 schemas. 

• Component models: These models integrate the e-speak service abstraction 
with standard component models such as (Enterprise) Java Beans, CORBA, and 
COM+. 

• Management protocols and standards: Support for SNMP, ARM, and DEN is 
planned. 

• Languages: An E-speak library exists for Java, but e-speak has been designed to 
be language independent. Any language can be used to construct an Session 
Layer Security message which is all that is required to use e-speak. 



Summary 

E-speak presents a uniform service abstraction, mediated access, and manipulation 
of Resource metadata. This creates an open service model, allowing all kinds of 
digital functionality to be reasoned about through a common set of APIs. New 
service types and semantics can be dynamically modeled using the common service 
representation of an e-speak Resource. 

The naming system provides active bindings and personal name spaces. The 
connection between Clients and Resources can be reasoned about and formed at 
run-time (upon each access if necessary) based on arbitrary search characteristics. 
Personalization of views and environments and hot-plug replacement of Resources 
all become possible. 

The access control is based on a Public Key Infrastructure using attribute 
certificates for scalable distributed security. This is supported by the Session Layer 
Security protocol which allows messages to be protected against tampering, 
eavesdropping or replay. In addition the Session Layer Security protocol allows 
unprotected messages to be sent, should security not be needed. Session Layer also 
supports authenticated tunneling for efficient and secure firewall traversal. 
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The metadata system defines Vocabulary models as first-class entities in the system 
that can be reasoned about in the same manner as all other services. Translation 
and lookup through scalable advertising services are integrated into the model. 
Service location and discovery can thus seamlessly deal with a situation where the 
Client describes its requirement in an X.500 schema, while the service provider 
describes its service using an XML DTD. 

The distribution model supports a flexible set of access methods. Thus, 
downloading printer drivers and the remote access of a file are equally well 
supported by the model. The separation of the infrastructure into interacting 
Logical Machines builds on the autonomous machine model provided by the Web. 

These are the defining features of an open services platform. The collection of the 
capabilities discussed above creates an environment where services on the Internet 
can interact in a secure, dynamic, manageable way. The next chapter of the Internet 
(e-services) is being written, and e-speak helps us understand it. 
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Outline 

E-speak Resources include all the entities called " Services" in the ESI. together with 
programs and data entities held in the Core to enable the use and management of 
Services. The Services are called "External Resources" in the Core software, and 
the aids to using them are called "Core-Managed Resources". The programs and 
data of an external Resource are not seen by the core, and are managed by an 
external Resource Handler. What is held in the core for any Resource is its 
metadata, consisting of: 

• Resource Description, allowing Clients to find the Resource. 

• Resource Specification, enabling use of the Resource. 

The types of Resource and a breakdown of the metadata that each Resource has are 
tabulated below. The terms will all be explained in this Chapter. 

(One complication has been left out of the diagram and will not be discussed in this 
Chapter: the metadata for any Resource is itself an instance of a core-managed 
Resource class called MetaResource. MetaResource is discussed in Chapter 4. 
"Core-Managed Resources' under ""Resource manipulation' on page 71" - the name 
of the interface used to act on Metadata.) 

In tile table below. Vocabularies and Contracts are separated from all the other 
Core-Managed Resources because tiiey are both types of Resource and items of 
metadata. Advertising is distinguished from other (external) Resources because an 
ESI is likely to handle advertising differently from the creation of Services, as J-ESI 
does. The e-speak Core makes no distinction between advertising and other 
external Resources. 
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METADATA 
ITEMS 



DESCRIPTION 

Vocab. Attribs. 
Vocab. Attiibs. 

Vocab. Attdbs. 



SPECinCATION 
Contract: 

Voc-aibs. 
Interface. 

Iiibox 

Security Masks 
Filter 

Owner pdbHc key- 
Owner ESName 
Handkr ESName 
Resource Specific 

Data 
Serviceld 
ESuid 
URL 

byValae (boolean) 
eventControl 



Figure 4 - Resource Types and Metadata 
RESOURCE TYPES 



Vocabs. Contracts Other Core-Managed External Sernces 

Resources (Direct) (Advertising) 



All metadata items apply to each of the Resource 

types 



A Client registers a Resource by sending a message to the Core-Managed Resource. 
ResourceFactory, containing the metadata. If the registration succeeds, the Core 
returns a name bound to this Resource to the Inbox specified by the client. The 
metadata will be held under the same name in the Repository. The metadata 
comprises the whole of the information the Core uses to handle requests for the 
service and searches for it. 
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Resource Descriptions 



The simplest Resource Description consists of a set of names and corresponding 
values, together with an ESName referring to a Vocabulary which specifies the kind 
of data under each name. For example, a translation Resource could have the 
description: 



es://17.561.12.337:12356/vocabs/transla- (Vocabulary reference) 
tion 



name (String) 

SourceLanguage 
TargetLanguage 

InputFormat 

OutputFormats 

Price 



value (Value) 



0x00 Japanese 



essential 
(boolean) 

true 



OxOE English. Korean, false 
Russian, Mandarin 

0x00 Unicode false 

OxOE ASCII, Unicode false 

0x08 20000 false 



This description is an instance of AttributeSet. The rows consisting of a name, 
a Value and the boolean essential are instances of Attribute . A 
ResourceDescription consists of one or more AttributeSet instances. 
Different parts of the description may have different Vocabularies, and if so must be 
expressed in different AttributeSet s. 

Vocabularies are explained at the end of this Chapter. Although each instance of 
Value has a value-type code (seen above) , a Vocabulary is needed to define its 
significance. The "price" could be in Yen per kilobyte of input, for example. 
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The boolean essential, if true, means that the Resource will not be returned in 
response to a SearchRecipe that omits this Attribute name and value. This can be 
used to set passwords for the discovery of a Resource, (The use of the Resource is 
controlled by the security mechanisms in (Chapter 5, ''Access ControF). 

Value class 

Instances ofValue have a l-byte tcode and an Object val . The tcode 
indicates the type of val. It is one of these static final codes defined in the class: 

STRING_TYPE_CODE = 0x0 0; 
LONG_TyPE_CODE = 0x01; 
DOUBLE_TYPE_CODE = 0x02; 
B00LEAN_TYPE_CODE - 0x03; 
BIG_DECIMAL_TYPE_CODE = 0x04; 
TIMESTAMP_TYPE_CODE = 0x05; 
DATE_TYPE_CODE = 0x06; 
TIME_TYPE_CODE = 0x07; 
INTEGER_TYPE_CODE = 0x08; 
FLOAT_TYPE_CODE = 0x09; 
CHAR_TYPE_CODE = OxOA; 
BYTE_ARRAY_TYPE_CODE = OxOB; 
BYTE_TYPE_CODE = 0x0 C; 
SHORT_TYPE_CODE = OxOD; 
SET_TYPE_CODE = OxOE; 
NAMEDOBJECT_TYPE_CODE = 0x0 F; 
OTHER_TYPE_CODE = OxFF; 
INVALID_BASE_TYPE_CODE = OxFF; 

In all but the following cases, a Value is marshalled in e-speak serialization format 
The exceptions are: 

• tCode = SET_TYPE_CODE: val contains a set of values. This is not 
supported in the current release. 

• tCode = BIG.DECIMAL, DATE, TIME, TIMESTAMP, NAMEDOBJECT: val 
is sent as a String. The first 4 types are taken from the Java packages: 

• j ava . math . BigDecimal , 

• java.sql .Date, 

• j ava . sql . Time , 

• j ava . sql , Timestamp . 
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Resource Specifications 

The ResourceSpecif ication class is defined below. 

public class ResourceSpecif ication 

boolean byValue; 
ESName contract; 
FilterSpec filter; 
ADR metadataMask; 
ADR resourceMask; 
ADR ownerPublicKey; 
ADR Serviceld; 

ESMap privateRSD; //Not exported if export by reference 
ESMap publicRSD; 

ESName owner; //Not exported 

ESName resourceHandler; //Not exported 

int eventControl; 

ESUID uid; 

String URL; 

} 

boolean byValue 

This flag governs the export of the Resource to another Logical Machine. See 
(Chapter 6, "Communication"), If byValue is True, a copy of the Resource itself 
will be included with the Resource Specification and Resource Description 
exported. The copy of the Resource can then be used on the receiving platform. The 
Core will provide this copy for Core-managed Resources. Currendy, there is no 
mechanism for providing copies of external Resources. They can only be exported 
"by Reference", and only used remotely. 

ESName contract 

The contract field is the name of the Contract Resource associated with the 
Resource. An e-speak Contract is not an agreement between parties, but a provision 
to make a [Resource usable. It can contain: 

• an interface which the Resource will implement. 
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• one or more Vocabularies which can be used to frame queries in a search 
for Resources implementing that interface. ^ 

A search may be required because several Resources may implement the same 
interface. 

A Resource cannot be registered without a valid contract field, so the Contract 
itself must have already been registered. The Contract given in the Specification of 
a Contract is ContractContract - what else? It is supplied by the Core. 

Contract implementation (informational) 

The current J-ESI creates ESContracts, containing an interface which has been 
generated by an Interface Definition Language (IDL) compiler, ES-IDL. The 
ESContract also contains Terms of Use, a Conversations scheme and the ESName 
of the interface. An ESContract creates a core Contract. All the interface 
information is put in the privateRSD field of this core Contract s metadata, in a 
format interpreted by J-ESLThe foUowing diagram illustrates this. 



Resource Metadata Descnption 

Specification Contract- Contract Metadata Descnption 

Specification. Contract (= ContractContnict) 

Fliter 

Public RSD 

RSD pubhc RSD 

». Pnvate RSD 

Interfece data 

A core Contract is constructed with an array of Vocabulary identifiers^ and a 
ResourceType. The latter is one of several integer constants defmed in the 
ResourceType class, and listed below. Contracts for all external Resources have a 
ResourceType of EXTERNAL_CODE, = 1000. Each Core-Managed Resource has an 
appropriately named ResourceType. 

Current ResourceTypes: 



1 Ttlis feature may be discontinued 



2 Vocabularies may be omitted from contracts in future releases 
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static int META_RESOURCE_CODE = 1; 

Static int PROTECTION_DOMAIN_CODE = 2; 

static int RESOXJRCE_FACTORY_CODE = 3; 

static int CONTRACT__CODE = 100; 

Static int CORE__DISTRIBUTOR__CODE = 110; 

Static int IMPORTER_EXPORTER_CODE = 120; 

static int MAPPING_OBJECT_CODE = 140; 

static int NAME_FRAME_CODE = 150; 

static int REPOSITORY__VIEW_CODE = 160; 

static int SECURE_BOOT_CODE = 170; 

static int SYSTEM_MONITOR_CODE = 180; 

static int VOCABULARY_CODE - 190; 

static int CORE_MANAGEMENT_SERVICE_CODE = 200; 

static int DEFAULT_VOCABULARY_CODE = 210; 

Static int DEFAULT_CONTRACT_CODE = 220; 

static int FINDER_SERVICE_CODE = 23 0; 

static int CONNECT ION_MANAGER__CODE = 240; 

static int REMOTE_RESOURCE_MANAGER_CODE 250; 

Static int EXTERNAL_CODE = 1000; 

static int EXTERNAL_RESOURCE_CONTRACT_C0DE = 1001; 
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Contract Methods 

Contract methods include: 

• void register (ResourceDescription, ResourceSpeciflcation, boolean 
persistence) 

• RepositoryHandle [] getVocabularies 0 

• void add Vocabulary (RepositoryHandle vocab) 3 

• String getResourceType 0 

ip • AbstractResource createResource (ResourceDescription, 

y ResourceSpeciflcation, boolean persistence. Object arg) 

• void SendObject(MessageOutputStream) used to export a Contract 

m • Object ReceiveObject(MessagelnputStream) used to import a contract 

1 1 This is only a sample. A RepositoryHandle is a unique identifier of an item in a 

j.I Repository (see Chapter 4, Xore-Managed Resources"). The last three methods 

^ provide a standard signature for creation, export and import of every kind of 

:^ ^ Resource. 

p FilterSpec filter 

r% class FilterSpec { 

ESSet Vocabularies; 
String constraint; 
} 

The filter is a way to restrict discovery of the Resource to particular Clients or 
classes of client. The constraint String is made up of conditions which the 
Client making a search must satisfy. All the names of Attributes must be in one of 
the Vocabularies, and all the values must be of the type and within the range 
specified in that Vocabulary. 



3 May be omitted in future releases 
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Filter implementation (informational) 

The constraint String has to specify a source for each Attribute value, and the 
Vocabulary for it if there is more than one - because the Vocabularies might include 
different Attributes with the same name. 

The source of Client details is commonly the Client s UserProfile - part of the 
AccountManager Resource (see Chapter 4, " Core-Managed Resources'*) . When this 
is so, the Attribute name in the constraint is prefixed $user/. Otherwise, the 
Attribute can only be taken from the Resource Description. For example, if a 
ResourceDescription and a UserProfile both include the Attribute "State", the 
constraint might include " $user/State = State" . 

If there are multiple Vocabularies, Attributes are preceded by the Vocabulary name 
and a colon. For instance, where Vocabularies called ^home" and ^workplace" are 
in the FilterSpec, the constraint could include "$user/home:State = 
workplace:State\ The second "State" here must be in the ResourceDescription. 

ADR metadataMask 

The metadataMask controls which operations manipulating the Resource s 
metadata will have security disabled - so no certificates or Message Authentication 
Code are required to invoke them. The interface name in the metadataMask will 
always be the ResourceManipulationlnterface. The format of the metadata Masks is 
specified in Chapter 5, "Access Control" - Section ""Disabling Security" on 
page 102". 

ADR stands for Ascii Data Representation. It is an abstract class: one extension of 
it is ADRAtom, and other extensions implement the interface Tag. These are the real 
classes which a metadataMask can instantiate. The Tag or ADRAtom identifies 
the operations that are free of security restrictions. Tags are described in (Chapter 
5/ Access Control"), 

ADR resourceMask 

The resourceMask determines which operations supported by the Resource will 
have security disabled. The format of the Resource Masks is specified in Chapter 5. 
"Access Control" - Section ""Disabling Security" on page 102". 
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ADR ownerPublicKey 

This field contains the owner's public key or a hash of it. The format is specified in 
Chapter 5, "Access Control" - Section ""SPKI BNF Formats" on page 109). The ADR 
extensions that can be used for ownerPublicKey are PublicKey and Hash. 



ADR Serviceld 

This field contains the serviceld of the Resource. Servicelds are defined in Chapter 
5, 'Access Control" - Section ""Service Identity" on page 88". This field can be any 
extension of ADR; it usually implements Tag. 



ESMap publicRSD 

"RSD" stands for Resource Specific Data. PublicRSD is used by the Client 
registering the Resource to insert any information he wants potential users to know. 

ESMap is an e-speak implementation of Hashtable. It consists of a series of Objects, 
each even-numbered Object being used as a key, and the following Object being the 
associated value. Both the key and value Objects are byte-arrays in the two RSD 
classes. ESMap is serialized as ESArray (see Chapter 6. ' Communication" for the 
e-speak serialization format for ESArray) . The e-speak convention for ESArray is 
that it consists of a sequence of pairs - preserving the key-value pairs of the ESMap. 

In the two RSD classes, no duplicate keys, null keys or null values are allowed. Any 
of these raises an exception. 



ESMap privateRSD 

This field is used by the Resource Handler when a Client sends a message to the 
Resource. Access to the privateRSD is commonly confined to the Resource 
Handler, but permission can be granted to any task using the e-speak security 
mechanisms. The use of this field in a Contract for the interface implemented by the 
Resource has been noted. Otherwise the field is most often used to carry the 
Resource Handler's designation for the Resource. 
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ESName owner 

The owner field is the ESName of the active Protection Domain of the Client that 
registered the Resource. A Protection Domain is a Core-Managed Resource 
corresponding to a user's home directory in Unix, or to a "folder" in J-ESI. (See [ E- 
speak Programmer's Guide] and Chapter 4, Core-Managed Resources".) This field 
can be changed to another Protection Domain by any Client that has authorization. 
It is an error if the ESName is not bound to any Protection Domain. 

The owner and resourceHandler fields are not included when the 
ResourceSpecification is serialized for export (see Chapter 6, Xommunication*'). 
The privateRSD field is only included in an export serialization if the export is by 
value. 



ESName ResourceHandler 

This is the ESName of the inbox, to which messages sent to this Resource will be 
delivered. This field is alwaysNULL for Core-managed Resources, and only for 
these. The Client that has coimected to this Inbox will receive messages for this 
Resource. (The format of these messages is defined in Chapter 6, Communication" 
- Section "Protocol Data Unit (PDU)"). It is an error if the ResourceHandler ESName 
specified by the Client is not bound to an Inbox. 



int eventControl 

If eventControl is non-zero, then whenever the Resource metadata (the 
Resource Description or the Resource Specification) is changed, an Event will be 
published to the Core's Event distributor. 

ESUID 

public class ESUID 

{ 

byte[] Uniqueld; 

} 
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An ESUID contains a byte array that is up to 64 bytes long. The ESUID of a Resource 
is guaranteed unique to a very high probability. As the URL and the Serviceld also 
identify the Resource, it is not certain that this field will be retained. Currently it is 
used in some Core programs. 

String URL 

This field is the ESName (represented as a String) by which the registering entity 
refers to the Resource. It is an ESName (URL) which others can use to access the 
Resource. 



Searches 

Search Context (Informational) 

A search is initiated by a Client. In the current J-ESI, the Client can create a Finder 
of one of three classes - ESVocabularyFinder. ESContractPinder or 
ESServiceFinder. Each has a find (ESQuery) method, where theESQueiy 
expresses the attributes the Client needs. Clients providing a Service are likely to 
use the ESVocabularyFinder, to obtain a suitable standard Vocabulary to describe 
the Service. This can make it more widely visible. Either providers or users may 
search for a standard Contract. A user may then: 

• Construct an ESServiceFinder, stating the Contract or its interface. 

• Use Vocabularies obtained from the Contract^ or an ESVocabularyFinder to 
frame an ESQuery argument 

• Call ESServiceFinder.flnd with that ESQuery to discover the Service he wants - 
in one or more stages. 



4 Contracts may not continue to hold vocabularies 
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If the J-ESI find is successful, a stub for the Resource is returned to the client. He 
can then call the Resource as if it were on the same platform. The stub will generate, 
serialize and send the PDU messages through the core needed to invoke the 
Vocabulary, Contract or Service methods (see Chapter 6, "Communication"). 

All three J-ESI Finders use the same core Finder Resource class, and there is no 
distinction in the core software between finding a Vocabulary, Contract or external 
Resource. The ESQuery is represented by a SearchRecipe, described below. The 
information content of the SearchRecipe will be the same as that of the ESQuery. 

Finder Resource 

This is a Core-Managed Resource to carry out a Client's find 0 command. It provides 
for searching in several stages, if many Resources satisfy the query. 

Initial Search 

An initial search is carried out by this method: 
interface Finderlnterf ace { 

FinderResults find (SearchRecipe recipe, int maxToFind) 
throws ESInvocationException, LookupFailedException; 

The argtmient maxToFind is the maximum number of results to return. If it is set 
to 0 then the request is only to know if there are any search results - not what they 
are. If it is set to -1 the method returns all results found. There is a field in 
SearchRecipe which serves the same general purpose, so maxToFind may be 
discontinued. We refer below to "the limit" however it is set. 

The returned FinderResults has these fields and public get — 0 methods to 
retrieve each of them: 

class FinderResults { 
private ESname[] esnames; 
private int [] servicelds; 
private FinderContext context; 

The first two fields contain ESNames and servicelds of Resources matching the 
SearchRecipe, The size of each array will be either the number of Resources which 
match, or the limit - whichever is least. A FinderResults method, boolean 
hasMoreResults ( ) returns true if there are more Resources than the limit 
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Follow-on searches 

If hasMoreResults () is true, then another batch, again up to the limit, can be 
obtained from a follow-on search, using the opaque FinderContext byte array 
context from the previous FinderResults. (The getContextO method 
obtains context , but is not available for Clients to use directly,) The follow-on 
method is: 

FinderResults find (FinderContext context) 

throws ESInvocationException, Lookup FailedExcept ion; 

} 

class FinderContext { 
byte [] queryContext 

Finder details: 

• The LookupFailedException is raised when there was an error in the Core during 
the search. 

• When the limit is 0, (meaning one only wants to know if any Resources match 
the SearchRecipe) the initial search will return a non-null FinderResults 
object if there are some. Call this "outcome" . The code: 

ESNames [] outray = outcome .getESNames {) ; 

will yield an array of length 1. but outray [0] will be null If there are no results, 
outcome is null, 

SearchRecipe 

A SearchRecipe is the expression of attributes a Resource must have to satisfy a 
Client s needs. Instances of the class are constructed with the following arguments: 

• ESSet vocabularies - a set of ESNames of the vocabularies holding the 
attributes used in the constraint and preferences. The registered names 
of these vocabularies are prefixed to the attribute-names in the constraint 
and preferences if more than one vocabulary is used - otherwise there could 
be confusion between homonymous attributes. 
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• String constraint - consisting of attribute-values, relational operators and 
logical operators, which must be satisfied by the corresponding attributes in a 
ResourceDescription, for the Resource to qualify. For instance: "price LE 20000 
AND maker's_name EQ Hewlett-Packard" could in principle be part of a 
constraint . (The current syntax used is different - see below.) 

• An optional ESArray preferences - an array of Preference objects, described 
below, which can be used to rank Resources in an order of preference, if more 
than one Resource satifies constraint. 

• An optional int arbitation - limiting the number of resources to return. 

• An optional ESName repositoryview - a set of RepositoryHandles delimiting 
the ResourceDescriptions which will be checked against the 
constraint . (See Chapter 4, "Core-Managed Resources''). 

SearchRecipe Context (Informational) 

Clients specify SearchRecipes only indirectly, using an e-speak API. The Core 
architecture only specifies the data types of the SearchRecipe fields, not their 
internal syntax or meaning. However, implementers may need to know about the 
latter, which is that of the corresponding fields in a Client s ESQuery. 

Constraint field 

The syntax of the constraint field conforms to the OMG Trader Services Constraint 
Language, except for the means of testing multi-valued attributes. See [ESRL Spec 
V4.1] and [CORBA services Document 12]. 

Preferences field 

The elements of the ESArray preferences are instances of the Preference class: 
class Preference 

{ 

final static int MIN= 1; 
final static int MAX= 2; 

final static in WITH= 3; 

private int type; 

private String expression; 

private String weight; 

} 
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The type must be MIN, MAX, or WITH. The expression must be subject to comparison 
operators if the element has type MIN or MAX. It must have a boolean value if type is WITH. 
A weight needs to be specified only for Preference elements of type WITH: it must then 
have a numeric value. The order of the MIN and MAX elements in the preferences array 
is important. 

Examples (omitting vocabulary qualifiers, and not using a formal syntax): 
MAX " Year.of.manufacture" 
MIN Trice* Mileage" 
WITHXolor== Blue" ^ 5" 
WITH Xolor!= Green "2" 

How Preferences work 

Assume these Preferences, in the order given, are used to order a set of car 
** Resources" which have already passed the constraint. 

• The WITH elements take precedence. Each car is given a score: the sum of the 
weights in the WITH tests that it passes. Any blue car will have a weight of 7 
(because it is blue and not-green). All blue cars will lead the list of preferences, 
followed by all other cars that are not green, with green cars at the bottom of the 
list. 

• In each set based on the WITH tests, the MAX and MIN comparisons are applied, 
in the order they are listed . The year 2000 cars will be at the top of each set based 
on the WITH weights. 

• Each year-group will finally be ordered by the MIN Price * Mileage test - those 
with the lowest Price.Mileage product coming first in their group. 

Arbitration field 

Any positive value N in this field means "Return up to N Resources". Suppose M 
Resources passed the constraint, then the number C = min(N, M) will be returned. 
If there are preferences, the first C in the preference list will be returned. Otherwise 
C Resources are returned, but the choice is undefined. 

The field may be negative, with values defined in: 
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class ArbitrationPolicy 

{ 

public static final int ALL= -1; 
// To return all resources passing the constraint 

public static final int ANy= -2; 
// To return 1 resource - the most preferred if there are 
preferences 

public static final int NEGOTIATE^ -3; 
// Reserved to invoke an arbitrator resource - not currently used 



Vocabularies 

An e-speak Vocabulary is a description of terms used in a Resource Description, in 
parts of a Resource Specification or in a Search Recipe. 

Formally, a Vocabulary is an Attribut ePropertySet. as described below, witti 
a description String. It is itself a (Core-Managed) Resource, with a 
ResourceDescription and Specification, and it can be searched for. The 

ResourceDescription of a Vocabulary must itself have a Vocabulary To end the 

recursion, the e-speak Core will ship with a Base Vocabulary ^veloddeA. The Base 
Vocabulary will always be in the Core and accessible to all clients. Descriptions that 
don't use any other Vocabulary use the Base Vocabulary. The Core also supplies a 
Vocabulary Contract, for the ResourceSpecification of a Vocabulary. 

The following diagram summarizes the use and make-up of Vocabularies. 
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Figure 5 Vocabularies and their Uses 
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Notes on Preceding Figure: 

• Items followed by a 1\ such as " essential T are boolean. 
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have the ValueType "Integer" in the entry for Trice" . 
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Vocabulary Context (Informational) 

Vocabularies are essential both to describe and specify Resources, and to discover 
them. Any Client can make up and register his own Vocabularies, but if most of 
them did so, we*d have a tower of Babel, or worse. It is expected that 
standardization bodies or Service associations will develop all the significant 
Vocabularies, advertise them and control them using Access Control (Chapter 5 
"Access ControF). 



Vocabulary class and methods 

The Vocabulary class is outlined below: 
class Vocabulary 

private String description; 
private AttributePropertySet props; 

String getDescription ( ) 
throws ESInvocationException; 

AttributePropertySet getProperties () 
throws ESInvocationException; 

boolean mutate Properties (AttributePropertySet props) 
throws ESInvocationException QuotaExhaustedException, 
StaleEntryAccessException; 

// Exchanges current AttributePropertySet for props - returns 

true if any difference 

boolean isLegalSet (AttributeSet ast) 

// Checks if ast is legal under this Vocabulary, using 
AttributePropertySet . isLegalSet () 
public Vocabulary release () 
public void finalize () 

// Both of these take the Vocabulary out of use 

The standard createResourceQ, sendObjectQ and receiveObjectQ methods are not 
listed. 
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AttributePropertySet (APS) Methods 

The following methods of AttributePropertySet are used in building a Vocabulary or 
registering a Resource 

• Object addAttributeProperty{AttributeProperty ap ) - this is the 
way an APS is built up. 

• boolean isLegalSet (AttributeSet attrs) - this is called by 
Vocabulary. isLegalSet ( ) to test whether attrs is valid for this APS. The 
tests made are: 

• Are all mandatory attributes included in attrs? 

• Is every attribute in a 1 1 r s in this APS? 

• Do all the tCodes of the Values in at t rs agree with the corresponding 
ValueType in the APS? 

• Where there is a range defined in the APS, is the Value of the corresponding 
Attribute in attrs within that range? 

• AttributePropertySet getMandatoryAttributes ( ) -used by the 
preceding method, and maybe by others. 

Attribute Properties 

An APS is an ESMap: it consists of a paired name and AttributeProperty 
instance for each Attribute in the Vocabulary. The name is duplicated within the 
At tribut eProperty . The following table shows the fields of 
AttributeProperty. 
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Table 2 Components of an attribute property 



Type 


Field 


Meaning 


String 


attrName 


Attribute name 


String 


description 


Human-readable description 


ValueType 


attrValueType 


See Table 3 for encoding 


Value 


defaultValue 


Default value 


String 


definition 


Expression to evaluate for a 
dynamic attribute 


boolean 


multivalued 


True if multiple values 


boolean 


mandatory 


The attribute must be specified if 
mandatory is True 


int 


rangeKind 


0 NO_RANGE 1 LEFT_RANGE 
2 RIGHT_RANGE 3 FULL^RANGE 


int 


keyfndexType 


Use for repository lookup: see 
below 


double 


minRange 


Smallest allowed value 


double 


maxRange 


Largest allowed value 



• defaultValue : If the attribute is absent from an AttributeSet A, and is not 
mandatory, the XXXXXX will insert it in A with defaultValue. 

• de f ini t i on : Dynamic attributes are not supported in the current release. 
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• multivalued: If this is true, an ESSet of values is expected, and the 
defaultValue should be such a set (See the e-speak serialization format in 
Chapter 6, ''Communication" for the definition of ESSet). 

• mandatory: If true, all AttributeSets under this Vocabulary must include the 
Attribute named. You won*t be able to register a Resource whose description 
uses the Vocabulary, if the AttributeSet lacks this Attribute. 

• rangeKind : specifies what kind of range-checking will be done on the 
Attribute s value, in relation to minRange and/or maxRange. The capitalized 
alternatives are integer constants defined (static final) for the class: 

• NO_RANGE - There is no restriction, whatever minRange and maxRange 
may be. 

• LEFT_RANGE - Values must be >= minRange 

• RIGHT_RANGE - Value must be <= maxRange 

• FULL„RANGE - Both LEFT_RANGE and RIGHT_RANGE rules apply. 

• keylndexType : To support lookup in a repository based on a Database 
Management System (DBMS). Valid values of keylndexType are: NOJNDEX 
(0), HASHJNDEX (1) and TREEJNDEX (2). If the value is HASHJNDEX or 
TREE JNDEX the attribute will be used for index look-up by the DBMS. This is 
discussed further in Chapter 10, Repository (Informational)". 

Class ValueType 

Instances of this class have the private fields: 

string typeName; // Must be one of the designators in Table 3 

String description; // Human-readable description 

string matcher; // An applicable relation, such as "islessThan'* 

int baseTypeCode; // Equal to tCode in Values, except for invalid Type 

typeName must be one of the Designators in the following table. These are defined 
(as static final String) in the ValueType class. Each corresponds to one of the 
allowable tcodes in class Value. The Matching rules and Operations are used to 
check the validity of expressions in a SearchRecipe or filter. 
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Table 3 Supported value types 



Data type 



Big decimal 



Designator 



'BigDecimal" 



Matching rules 



eq, ne. It le, gt ge 



Operations 



Boolean 



'Boolean" 



eq, ne 



AND, OR 



Byte 



" Byte'' 



eq, ne 



Byte array 



"ByteArray" 



eq, ne 



Char 



Date 



"Char" 



eq, ne 



"Date" 



eq, ne, It, le, gt ge 



+ (concatenate, 
returns String) 



Double 



" Double" 1 



eq, ne, It le, gt, ge 



Float 



"Float" 



eq, ne, It, le, gt ge 



Int 



"Integer" 



eq, ne, It le, gt ge 



Long 



^Long" 



eq, ne. It, le, gt, ge 



^/ 



Object 



"NamedObject" 



Short 



'Short" 



eq, ne, It le, gt ge 



String 



'String' 



eq, ne 



+ (concatenate) 



Time 



"Time" 



eq, ne. It, le, gt, ge 



Time stamp 



"Timestamp' 



eq, ne. It le, gt ge 



tquanty tesis witn a t-ioai or uouDle may give "talse" unexpectedly 



46 



Developer Release X.03.03.00, September 2000 



Resource Data, Searches & Vocabularies 



Vocabularies 



Base Vocabulary 

The Base Vocabulary available at system start-up includes the attributes and value 
types shown in Table 4. 

Table 4 Base Vocabulary definition 



Attribute name 


Value type 


Comments 


Name 


String 




Type 


String 




ResourceSubtype 


String 




ESGroup 


String 




ESCategory 


String 




Description 


String 




Keywords 


String 


Multivalued 


Version 


String 




ESDate 


Date 


"YYYY-MM-DD" 


ESTime 


Time 


"HH:MM:SS" 


ESTimeStamp 


TimeStamp 


^TYYY-MM-DD 
HH:MM:SS.FFFFFFFFF" 


HashAlgorithm 


String 




HashCode 


BigDecimal 


To authenticate contents 



The hash algorithm is specified using well-known names, for example, MD5. 
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Base Account Vocabulary 

The Base Account Vocabulary is also available at startup. It is used for discovering 
user accounts. 

Table 5 Base Account Vocabulary 



Attribute name 


Value type 


UserName 


String 


Userlnfo 


String 


UserType 


String 


UserLocation 


String 


UserESURL 


String 



The above attributes match the fields defined in Authlnfo and UserProfile. For more 
information, see" The Account Manager Resource" section in Chapter 4, * Core- 
Managed Resources." 

The description string for the Base Account Vocabulary is: "E-speak base user 
vocabulary". 

Translators (Informational) 

The interoperation of different Vocabularies may be supported through Vocabulary 
Translators, The translator would map attributes from one Vocabulary into 
another, but there is no direct linkage between a Translator Resource and any 
Vocabulary Resource. A translator service is not part of the e-speak architecture; it 
would be an external Resource. 

The translator envisaged would implement: 

ESName [] [2] getVocabularyPairs () ; 
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which queries the translator about Vocabularies known to it. The translator returns 
an array listing all Vocabularies that it can translate in an ordered set. Each element 
in this array is a pair of Vocabulary names. 

boolean isCompatible (Vocabulary vocabularyl, 
Vocabulary vocabulary2) 

checks if the translator can translate from the first given Vocabulary into the second 
given Vocabulary. If the translator can perform the translation operation on the 
given pair of Vocabularies, it wiU return true. If the translator cannot perform the 
translation, or if it does not understand either of the Vocabularies, it will return 
false. The translation is done by: 

SearchRecipe translate (SearchRecipe s. 
Vocabulary v2; 

which returns a Search Recipe in the specified Vocabulary. 
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Clients interact with the e-speak Core by sending messages to Core-managed 
Resources. For example, the Resource Factory is used to register new Resource 
metadata. This Chapter lists all the core-managed resources and describes those 
which are not described in other Chapters. It also describes the internal state that 
is passed if the Core-managed Resource is exported by value to another Logical 
Machine. 



Conventions 

All the methods described in this Chapter throw ESInvocationExcept ion (see 
Chapter 7, "Exceptions"), the base class for exceptions thrown by the e-speak Core 
to the Client during message processing. 

Each class, of which instances can be exported by value, starts with a list of static 
declarations. Each declaration contains a permissible content of the payload in a 
PDU (see ) requesting the core to invoke a method in that class. 



The Account Manager Resource 

The Account Manager Resource is for managing user accounts on an e-speak Core. 
A user account contains information about the user including its PSE (Private 
Security Environment) . This enables a user to authenticate to the Account Manager 
(via userid, password) and to retrieve its PSE. In the current implementation it will 
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then need a passphrase to unlock the PSE to access its key material. The placing of 
the PSE under the Account Manager Resource does not implement the SPKI 
requirement for absolute security of private keys (see Chapter 5, "Access ControF) . 

User Profile 

The class UserProfile defines the basic information stored by the Account Manager 
for each user. 

class UserProfile { 
Authlnfo authlnfo; 
String userESURL; 
String userinf ormation; 
String userType; 

Prof ileAttributeSet preferences ; 

byte [] pse; 

} 

User Identity 

The class Authlnfo defines the basic information used by the Account manager to 
identify a user 

class AuthInfo{ 
String userName; 
String passPhrase; 
String homeAddress ; 
} 

The home address indicates the "home e-speak Core of a user" in host;portNumber 
format. An example is: 

myhost . myCo . com: 1234 

User's Account 

The userESURL is the ESName of the user's Account Resource. This is a Protection 
Domain, This ESName is bound to the user s Protection Domain in a Name Frame 
created by the Account Manager. Note that this ESName also includes the host and 
portNumber of the user's "home e-speak Core". An example of a userESURL is: 

es : / /myhost . myco . com: 12345/Core/AccountManager/ 
myhost . myco . com : 12 3 4 /myName 
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When the Account is registered a Protection Domain is created and registered using 
the Base Account Vocabulary (see in Chapter 3, "Resource Data. Searches & 
Vocabularies') with attributes from Authinf o and userProf iie. This means the 
Account Resource (Protection Domain) can be discovered using attribute-based 
find 0 Just like any other e-speak Resource. 

User Type and Information 

UserType and Userlnformation are arbitrary strings that can be assigned by an 
application. These are defined in the BaseAccount Vocabulary, so they can be used 
to find Users. 

Private Secure Environment (PSE) 

The byte array pse is opaque, not interpreted by the e-speak Core, 
Preferences 

The <Prof ileAttributeSet pref erences> field is a set of name, value pairs 
defined as follows. 

class Prof ileAttributeSet { 
AttributeSet attrs; 

String format; 

} 

If the format string is set to "vocab", the AttributeSet attrs will be defined in a 
vocabulary specifed in the attrVocab field of the AttributeSet (see Chapter 3, 
"Resource Data, Searches & Vocabularies"). Otherwise the format string will be set 
to "SIMPLE" and attrs will contain an arbitrary set of name-value pairs, not 
necessarily valid in any vocabulary. 

The ProfileAttributeSet contains secret information. The intent is that this 
information should not to be visible to any application odier than the one that 
registered the accoimt.. 
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Account Manager methods 

The following methods can be specified in the method field of a 
MessageForResource PDU with AccountManagerlnterface in the interface field. 

public interface AccountManagerlnterface { 
public String registerUser (UserProf ile up) 

throws PermissionDeniedException, StaleEntryAccessException, 
NameNo t FoundExc ep t i on ; 

public boolean unregisterUser (Authinf o authlnfo, 
String accountName) 

throws PermissionDeniedException, StaleEntryAccessException, 
NameNotFoundException; 

piiblic boolean authenticateUser (Authinf o authinf o) 

throws PermissionDeniedException, StaleEntryAccessException, 

NameNotFoundException ; 

public UserProf ile getUserProf ile (Authinf o authlnfo, 
String accountName) 

throws PermissionDeniedException, StaleEntryAccessException, 
NameNotFoundException; 

public boolean setUserProf ile (Authinf o authlnfo, UserProf ile up) 
throws PermissionDeniedException, StaleEntryAccessException, 
NameNotFoundException ; 

public String[] getAllUsers () 
throws ESInvocationException; 

public boolean addDescription (Authinf o authlnfo. 
String accountName, AttributeSet as) 
throws ESInvocationException; 

public String getUserESURL (String accountName) 
throws ESInvocationException; 

The function getAllUsers returns a list of the ESNames (in stringifled form) of 
the Account Resource (Protection Domains) of all registered users. 
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The function addDescript ion is used for adding a new AttributeSet to the user's 
Account Resource (Protection Domain), This can be in any vocabulary, not just the 
Base Account Vocabulary. 

The accountName parameter in getUserProf ile and getuserESURL must match 
the userName in the Authinf o of the intended account. 

The function getuserESURL returns a String corresponding to the ESNames(URLs) 
of the user's Account Resource (Protection Domain). 



Connection manager 

The connection manager is described in Chapter 6/ Communication" . 



Core management resource 

The core management Resource is deprecated in the current release. It may later be 
part of a Management API, and/or be changed. The current methods are: 

interface CoreManagementlnterf ace extends ManagedServicelntf { 

int ping(int pingValue) 
throws ESInvocationException; 

ESName [ ] ge 1 01 i en t Conne c t i ons { ) 
throws ESInvocationException; 

boolean stopServingOutbox (ESName Protect ionDoma in) 
throws ESInvocationException; 

boolean stopServinglnbox {ESName Inbox) 
throws ESInvocationException; 

boolean s t art ServingOutbox (ESName Protect ionDomain) 
throws ESInvocationException; 

boolean start Servinglnbox {ESName Inbox) 
throws ESInvocationException; 

boolean removeProtect ionDomain (ESName Protect ionDomain) 
throws ESInvocationException; 

boolean denyNewClientSessions ( ) 
throws ESInvocationException; 

boolean acceptNewClientSessions () 
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throws ESInvocationException; 

long getTotalMemory { ) 
throws ESInvocationException; 

long getFreeMemory () 
throws ESInvocationException; 

void startJVMGCO 
throws ESInvocationException; 

void stopJVMGC 0 
throws ESInvocationException; 

void setJVMGCInterval (int millis) 
throws ESInvocationException; 

int get JVMGCInterval ( ) 
throws ESInvocationException; 

boolean isJVMGCRunning ( ) 
throws ESInvocationException; 

void startScavenger 0 
throws ESInvocationException; 

void stopScavenger ( ) 
throws ESInvocationException; 

void setStatsNum(int num) 
throws ESInvocationException; 

ESArray^ getScavengerStats { ) 
throws ESInvocationException; 
} 

The Core Management Resource provides a way for a client to manage its core. By 
invoking the Resource on another core it can use the same methods on that too. 
(The client must have appropriate certificates in any case.) The Core Management 
Resource is itself a Core-managed resource: it implements the interface 
ManagedServicelntf described in Chapter 9. ** Management". 

The method ping checks that the core is up and returns the value specified 

The method getclient Connect ions returns a list of protection domains that 
are currently being used. 

The methods stopServingOutbox and startServingOutbox tell the e-speak core 
to stop or start serving the outbox associated with the protection domain specified. 

The methods stopServinglnbox and startServinglnbox tell the e-speak 
Core to stop or start serving messages to the Inbox specified. 
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The method removeProtectionDomain removes the Protection Domain 
specified. Any client using the Protection Domain is disconnected and any 
Resources contained in the Protection Domain are deregistered. 

The methods denyNewClient Sessions and acceptNewCIientSessions tells the 
e-speak core to stop or start accepting new connections from clients. 

JVM management methods 

The following methods are specific to e-speak Cores implemented in Java. Some e- 
speak Cores may not implement these methods: if so, the method will return a 
MethodNotlmplemented exception. 

The methods getFreeMemory and getTotalMemory get the free memory or total 
memory in the e-speak Core s Java Virtual Machine (JVM) . 

The methods start JVMGC ( ) and stop JVMGC ( ) start and stop the e-speak Core s 
JVM garbage collector. 

The methods set JVMGCInterval and get JVMGCInterval ( ) set and get in 
milliseconds the interval between runs of the JVM garbage collector. 

The method is JVMGCRimning ( ) returns true if the JVM garbage collector is 
running. 

Scavenger management methods 

The current implementation of the e-speak Core has a scavenger that looks for 
resources in the repository that are no longer valid and removes them. It can 
remove resources even if references to them still exist, unlike the JVM garbage 
collector. Examples of resource that may no longer be valid include the following. 

• Resources registered in a Protection Domain that has been removed. 

• Resources imported from another e-speak Core after the connection to that 
Core is closed. 

Some e-speak Cores may not implement these methods: if so the method will return 
a MethodNotlmplemented exception. 

The methods startScavenger and stopScavenger enable and disable the 
scavenger from running. 
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The scavenger also records statistics for each run as follows. 

class ScavengerStats 

Int runNo; 

Long timeElapsed; 

Int numlnspected; 

Int numCollected; 

Int totalNumlnspected; 

Int totalNumCollected; 

String phase; 

The runNo field indicates the current run (the first run is run number 1) . 

The timeElapsed field is the time taken for the run in milliseconds. 

The field numlnspected indicates the total number of Resources inspected in this 
run. 

The field numCollected indicates the total number of Resources removed in this 
run. 

The fields totalNumlnspected and totalNumCollected are the rtmning totals 
since the e-speak Core was started. 

The phase field will contain the string " Mark" or " Sweep" , this denotes whether the 
run was a "mark" or "sweep" run. Resources are only removed from the repository 
(and the numCollected count incremented) on a sweep run. There is no notion of 
"mark" or "sweep" phases on Resources in the cache. 

The scavenger keeps statistics for a certain number of runs. This is set by method 
setStatsNumin the CoreManagementlnterface. The method 
getScavengerStats returns an ESArray of containing an instances of 
ScavengerStats in each element. (The current implementation returns an instance 
of the Java Vector class.) 
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Finder Resource 

The finder, with a principal method 

FinderResults f ind (SearchRecipe sr) 

is discussed in Chapter 3, "Resource Data, Searches & Vocabularies\ It enables 
discovery of Resources matching the SearchRecipe, and optionally putting them in 
an order of preference, by examination of the Resource Descriptions in the 
Metadata. 



Mailbox 

E-speak has both Outboxes and Inboxes, but only Inboxes are exposed to Clients 
as Core-managed Resources. The Core s only actions on outboxes are the 
startServingOutbox ( ) and stopServingOutbox ( ) methods of the 
CoreManagementlnterface. An Inbox is where a Client gets messages from the 
Core. A Client can have more than one Inbox, but each Inbox must be explicitly 
connected by the Client before it can be used to receive messages. 

An Inbox cannot be exported. 

The Inbox class implements the Mailboxlnterface defined below: 

interface Mailboxlnterface 

{ 

boolean isConnected ( ) 

throws ES I nvocationExcepti ©ne- 
void connect (int slot) 

throws ESInvocationException; 

void disconnect 0 
throws ESInvocationException; 

void reconnect (int slot) 
throws ESInvocationException; 

} 
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An Inbox is a Core-managed Resource that provides a unidirectional 
communication channel from the e-speak Core to a Client, When a Client registers 
a Resource with the e-speak Core, it must assign an Inbox Resource as the 
Resource Handler** for the Resource. Any service requests directed to the Resource 
are delivered to the Client on the I/O channel associated with the Inbox that was 
named the Resource Handler. 

An Inbox can be in one of the two states: connected or disconnected. Upon 
creation, the Inbox starts in the connected state. The creator of the Inbox becomes 
the owner of the Inbox, and the Inbox is set up to use the I/O channel information 
passed with the request to create the Inbox. The Inbox remains in the connected 
state until the Client requests an explicit disconnect, or until the I/O channel 
associated with the Inbox is closed, at which time it is put in the disconnected state. 
If a Client sends a message to a Resource whose handler is an Inbox in the 
disconnected state, an exception is thrown by the e-speak Core. 

One may argue that Inboxes are unnecessary and that the e-speak Core could store 
the I/O channel information in the Resource Handler field directly. There are two 
main reasons for having the Inbox store the I/O channel information and not the 
Resource- one has to do with Client restart, and the other with delegation. These 
are explained in the following subsections 

Inbox and Client Restart 

In the e-speak environment, a Client can recover from some types of failures, one 
of which is the failure of a Client process. If a Client process dies and restarts, it can 
reconnect to the Core, discover and activate its previous Protection Domain, and 
discover and connect to the Inboxes owned by it. That way it can continue to serve 
the Resources that were registered by it during its previous incarnation. 

Connecting to an Inbox involves updating the I/O channel information maintained 
by the Inbox. Keeping the I/O channel information in the Inbox helps simplify the 
Client s job at restart. It only has to discover and re-connect to one or a few inboxes. 
If, instead, the I/O channel information is stored in all the Resources registered by 
the Client, it would somehow need to be updated all over the place upon 
reconnection by the Client. 
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Inbox and Delegation of Resource Handling 

Under certain circumstances, a Client may want to delegate the handling of one or 
more Resources served by it to another Client. Inboxes make the delegation easy. 
Let*s say Client A has registered 100 Resources, and named Inbox IB as its handler. 
After a while, Client A wants Client B to take over the handling of all these 
Resources. This can be achieved as follows: 

1 Client A passes the name of the Inbox IB to the other Client, along with a 
certificate to perform a reconnect operation on the Inbox. 

2 Client B requests the e-speak Core to reconnect it to the Inbox IB. The Core 
replaces Client As FO channel information with Client B s I/O channel 
information, 

3 Any further service requests directed to any of the 100 Resources are diverted to 
the I/O channel specified by Client B. The process of reconnection is performed 
atomically. Though logically the reconnect operation involves a disconnect 
operation on behalf of Client A and a connect operation by Client B, no one 
really sees the transient disconnected state. 



Name Frame 

A Name Frame manages the bindings of ESNames to Resources. A Client s default 
Name Frame is part of its Protection Domain. This section first describes the 
structure of an ESName and a binding and then describes Name Frames and data 
structures used by Name Frames. 

ESNames 

The only way a Client can refer to a Resource when communicating with the Core 
is to specify an ESName for the Resource. ESNames are defined fully in Chapter 6, 
"Communication" , Section ""ESNames" on page 165\ 
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Bindings 

In e-speak. a name is bound to a Mapping Object which consists of an array of 
Accessors. An Accessor can be one of two types, as represented in Table 6. 



Table 6 Mapping Object accessor types and descriptions 



Accessor Type 


Descriptions 


Search request 


A set of attributes, their corresponding values, and a 
Vocabulary to use in interpreting them 


Explicit binding 


A single instance of a Resource 



Thus, a name can be bound to: 

• Zero or more Resources 

• Zero or more Search Recipes 

• Some combination of explicit bindings and search request bindings 

The term simple bindingis applied to a name bound to a Mapping Object that has 
a single explicit binding. The term complex bindingis used otherwise. 

NameSearchPoiicy 

A NameSearchPoiicy is used when a find request has returned some bindings. 
The NameFramelnterf ace listBindings or listNames methods listed 
below are used with a NameSearchPoiicy argument: 

class NameSearchPoiicy 

static final int NSP_ANY = 0; 

static final int NSP__SIMPLE = 1; 

static final int NSP_EXPLICIT = 2; 

static final int NSP_PARTIAL 3; 
ESName contract; 
int bindingType; 
boolean matchSense; 

} 
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NSP_ANY means match any binding types. NSP_SIMPLE means match simple 
binding types. NSP_EXPLICIT means match explicit binding types. NSP_PARTIAL 
means match partial binding types (this is not implemented in the current release, 
and will cause undefined behavior if used). 

If matchSense is false, the meaning of the Name Search Policy is negated, so 
listBindings will return the names of bindings that do not satisfy the Name 
Search Policy. 



Name Frame Methods 

Some NameFrame methods throw ESSeirv-iceException, Chapter 7, 
Exceptions'* lists the exception hierarchy for NameFrame methods. 

The NameFrame methods are defined below: 

interface NameFramelnterf ace 
{ 

boolean isBound (String baseName) 
throws ESInvocationException; 

void bind (String baseName, SearchRecipe recipe) 
throws NameCollisionException, QuotaExhaustedException, 
ESInvocationException, ESServiceException; 

void rebind (String baseName, SearchRecipe recipe) 
throws ESInvocationException, NameCollisionException; 

void unbind (String name) 
throws ESInvocationException, I nvalidName Except ion 
QuotaExhaustedException; 

void rename (String oldName, String newName) 
throws ESInvocationException, ESServiceException 
InvalidNameException, NameCollisionException; 

void copy (String toName, ESName from) 
throws ESInvocationException, ESServiceException 
NameCollisionException, InvalidNameException, 
StaleEntryAccessException, QuotaExhaustedException; 

void add (String name, ESName from) 
throws ESInvocationException, InvalidNameException, 
StaleEntryAccessException ; 
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void subtract (String name, ESName from) 
throws ESInvocationException InvalidNatne Except ion, 
StaleEntryAccessException; 

String [] listNames (NameSearchPolicy nsp) 
throws ESInvocationException, NameNotFoundException; 

String [] listBindings (String aBaseName, 
NameSearchPolicy nsp, 
ESName target Frame) 

throws ESInvocationExceptionlnvalidNameException, 
StaleEntryAccessException, QuotaExhaustedException; 

A Name Frame can be exported by value or by reference. In the case of export by 
value, the Name Frame state is the bindings ESMap. The serialization for ESMap is 
defined by the e-speak serialization format. ESMap is an ESArray in which the 
convention is that consecutive elements are treated as pairs. In the case of bindings, 
the first element of a pair is the string component of ESName; the second is a 
MappingOb j act to vi^hich ESName is bound. A MappingObject consists of a set of 
SearchRecipes and explicit bindings to resources. The explicit bindings are internal 
pointers (repository handles) to the resource metadata in the e-speak Core's 
repository. A MappingObject is serialized as an ESSet containing the SearchRecipes 
in the MappingObject (expUcit bindings are not contained in the serialized form 
transmitted in the case of pass by value). 

All methods that create a new entry in a Name Frame return a Name Collision 
Exception if the name already appears in the target Name Frame. An explicit rebind 
or unbind is required before the name can be reused. 

The isBound method checks to see if the specified name (baseName) is bound in 
this Name Frame. It returns true if the name is bound. 

The method bind binds SearchRecipe to a specified name (baseName) in this 
Name Frame, 

The method rebind changes the binding of the specified name (baseName) in this 
Name Frame to the new SearchRecipe. 

The method unbind removes the binding from NameFrame, 

The method rename renames the binding associated with oldname to newname . 
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The method copy copies the binding of from to toName. 

The method add adds the binding of from to the binding of name to give a new 
binding for name. 

The method subtract subtracts the bindings of from from the bindings 
associated with name to give a new binding for name. 

The method listNames returns an array of strings corresponding to all bindings 
that match NameSearchPol i cy nsp. The Name Search Policy allows the Client to 
specify the type of binding and/or Contract in which the Resource is registered. 

The method 1 istBindings lists all the bindings of the argument aBaseName that 
match NameSearchPolicy nsp. These bindings are placed in the NameFrame 
named by targetFrame. The return value is an array of String, each element 
being the name of a new binding in targetFrame. 



Protection Domain 

A Client s Protection Domain is analogous to a user's home directory in an 
operating system. It contains a root Name Frame in which the Client can place 
bindings. 

Each Protection Domain is associated with a quota. The goal of this is to track and 
manage use of space in the Repository. To support this, each Protection Domain has 
three fields associated with it: used, soft limit, and hard limit. A Protection Domain 
is guaranteed to be able to allocate Resources up to its soft limit. A Protection 
Domain may be able to allocate Resources up to its hard limit, depending on the 
memory usage of the Core. The default hard limit is 10,000,000 bytes, and the default 
soft limit is 30,000 bytes. 

A Protection Domain cannot be exported. 

The ProtectionDomain interface is defined below: 

interface ProtectionDomainlnterf ace 

{ 

ESName [] switchPD ( ) 
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throws ESInvocationException, PermissionDeniedException, 
NameNotFoundException StaleEntryAccessException, 
QuotaExhaustedException; 

Ob j ect [] getQuotaInf o ( ) 
throws ESInvocationException PermissionDeniedException, 
NameNotFoundException; 

Object [] setQuotadong softQuota, long hardQuota) 
throws ESInvocationException, PermissionDeniedException, 
NameNot FoundExcep t ion ; 

ESName newProtectionDomain (String name, 
boolean persistent 
) 

throws Permi s s ionDeni edExcep t i on ; 

The method switchPD switches the Client s active Protection Domain to this 
Protection Domain (i.e., the Protection Domain receiving the method invocation). 
It returns an array of two ESNames. Element [0] is the ESName for the old 
Protection Domain, and element [1] is the ESName for the new Protection Domain. 

TheObject[] array returned by getQuotaInf o and setQuot a contains at least 
three values. The first is Long containing the total number of bytes currently 
consumed in the Core by this Protection Domain. The second is Long containing 
the soft limit in bytes. The third is Long containing the hard limit in bytes for this 
Protection Domain. 

The method newProtectionDomain creates a new Protection Domain. The 
name parameter is the name given when registering the new Protection Domain in 
the default vocabulary. The parameter persistent is set to true, if the new 
Protection Domain is to be made persistent. The return value is the ESName of the 
new Protection Domain. 

The following initial names are defined in the default NameFrame of a new 
Protection Domain: 

"CurrentPD" is bound to the Protection Domain itself 

"Core" is bound to the core name frame (es://host/core) (see Chapter 6, 
" Communication , section on ESNames) . 
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Remote resource manager 

The Remote Resource Manager is described in Chapter 6, Xonimunication\ 



Repository 

This is described in Chapter 10, "Repository (Informational)". 



Repository View 

A Repository View contains references to a set of Resources. 

When a Client does a find in a Repository View, the Core will attempt to match only 
those Resources included in the view. If no match is found, no accessor is added to 
the Mapping Object. 

A Repository View can be exported by reference or by value. 
The RepositoryView class is defined below: 

class RepositoryView 

ESName [] Resources; 

boolean add {ESName res) 
throws ESInvocationException PermissionDeniedException, 
StaleEntryAccessException, NameNotFoundException, 
QuotaExhaustedExcept ion ; 

boolean remove (ESName res) 
throws ESInvocationException PermissionDeniedException, 
StaleEntryAccessException, NameNotFoundException, 
QuotaExhaustedException; 

boolean contains (ESName res) 
throws ESInvocationException PermissionDeniedException, 

StaleEntryAccessException, NameNotFoundException; 
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boolean clear {) ; 
throws ESInvocationException QuotaExhaustedException 
PermissionDeniedException, NameNotFoundException; 

boolean addExternalLookupHandler (ESName res) ; 
throws ESInvocationException PermissionDeniedException, 
StaleEntryAccessException, NameNotFoundException; 

boolean removeExternalLookupHandler ( ) 
throws ESInvocationException StaleEntryAccessException 
PermissionDeniedException, NameNotFoundException; 

An externalLookupHandler is not used in this release. Any attempt to use 
addExternalLookupHandler or removeExternalLookupHandler will 
cause undefined behavior. 

In general, all methods return true if they are successful, false if they fail. Clients can 
add Resources to and remove Resources from a Repository View. Attempts to add 
a Resource already in a Repository View will fail, as will attempting to remove a 
non-existing Resource. The method clear removes all Resources from the 
Repository View. The method contains returns true if the Resource, res, is 
contained in the Repository View. 
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Resource Contract 

An e-speak Resource Contract is not an agreement between a Client of a Resource 
and the Resource Handler, Instead, it states the interface to which the Resource 
Handler will respond and conform. 

Two Resource Contracts are available at system start-up in addition to those for 
Core-managed Resources. The default Resource Contract allows any Client to 
register a Resource. It is useful for Clients wishing to define Resources that don't 
specify a particular interface, such as Callback Resources. The second Resource 
Contract is for creating new Resource Contracts. 

A Resource Contract contains a type string. This denotes the Resource type that is 
registered in this Resource Contract. A Resource Contract also contains a set of 
Vocabularies that can be used to discover and call upon Resources of this type2, 
A Contract can be exported by value or by reference. 
The ResourceContract class is defined below: 

class ResourceContract 
{ 

ESName[] Vocabularies; 
string type; 

void getVocabularies {ESName targetFrame) ; 
throws ESInvocationException PermissionDeniedException, 
StaleEntryAccessException, NameNotFoundException; 

The method getVocabularies populates the Name Frame. targetFrame, with 
the names of the Vocabularies supported by the Resource Contract. The Name 
Frame targetFrame is cleared before the operation. 



2 This may be omitted in future releases 
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Resource Factory 

A Client wishing to register a Resource with an e-speak Core uses the Resource 
Factory. This is also used for creating Core-managed Resources. 

The ResourceFactorylnterf ace class is defined below: 
^ class ResourceFactorylnterf ace 

void registerResource ( 
ResourceDescription descr, 
ResourceSpecif ication spec. 
Boolean persistence. 
Object param, 
ESName targetPrame, 
String toBaseName 
) 

throws ESInvocationException PermissionDeniedException, 
StaleEntryAccessException, NameNotPoundException, 
Name Co 1 1 i s i onExc ep t i on ; 

The registerResource method takes a ResourceDescription and a 
ResourceSpecif ication as parameters. If persistence is true, the Core will 
preserve the metadata after the Client s connection is closed, and also the state, in 
the case of a core-managed Resource only. The state of an external Resource is 
never preserved after the Client's connection is closed. The targetFrame 
parameter is the ESName of a Name Frame in which the name for the new Resource 
will be put. The toBaseName parameter is the name of the new Resource in the 
Name Frame. The Object par am is intended to hold Resource-specific information 
for creating Core-managed Resources, but is not currentiy used. It can be of any 
type supported in the e-speak serialization format. 
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Resource manipulation 

Every instance of e-speak provides a MetaResource that provides access to 
metadata (Resource Descriptions and Resource Specifications). Once a Resource 
has been registered using a Resource Factory, the only way to access its metadata 
is through a message sent to the MetaResource, using the 
ResourceManipulationlnterf ace defined below. 

MetaResources are not exported. 

interface ResourceManipulationlnterf ace 

void unregister (ESName resource) 
throws ESInvocationException; 

void setResourceOwner (ESName resource) 
throws ESInvocationException; 

ESName getResourceOwner (ESName resource) 
throw ESInvocationException; 

ESName getRe source Proxy (ESName resource) 
throws ESInvocationException; 

void setResourceProxy (ESName resource, 
ESName resourceHandler) 
throws ESInvocationException; 

ESName getResourceContract (ESName resource) 
throws ESInvocationException; 

ADR getMetadataMask (ESName target) 
throws ESInvocationException; 

void setMetadataMask (ESName target, ADR mask) 
throws ESInvocationException; 

ADR getResourceMask (ESName target) 
throws ESInvocationException 

void setResourceMask (ESName target, ADR mask) 
throws ESInvocationException 

ADR getOwnerPublicKey (ESName target) 
throws ESInvocationException; 
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void setOwnerPublicKey (ESName target, ADR key) 
throws ESInvocationException 

ESMap getPublicRSD (ESName resource) 
throws ESInvocationException; 

void setPublicRSD (ESName resource , ESMap rsds) 
throws ESInvocationException ; 

ESMap getPrivateRSD (ESName resource) 
throws ESInvocationException; 

void set PrivateRSD (ESName resource, ESMap rsds) 
throws ESInvocationException; 

ResourceDescription getResourceDe script ion (ESName target) 
throws ESInvocationException; 

void setResourceDescript ion (ESName resource, 
ResourceDescription desc) 
throws ESInvocationException; 

int getEventControl (ESName resource) 
throws ESInvocationException; 

void setEventControl (int setting) 
throws ESInvocationException; 

boolean isPersistent (ESName target) 
throws ESInvocationException; 

boolean isTransient (ESName target) 
throws ESInvocationException; 

void setPersistent (ESName target) 
throws ESInvocationException; 

void setTransient (ESName target) 
throws ESInvocationException; 

ESUID getESUID (ESName target) 
throws ESInvocationException; 

ESName getUrl (ESName target) 
throws ESInvocationException; 
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long getQuota(ESNanie target) 
throws ESInvocationException; 

ResourceType get Type (ESName target) 
throws ESInvocationException 

ADR getServicelD (ESName target) 
throws ESInvocationException 

void setServicelD (ESName target, ADR id) 
throws ESInvocationException 

All methods can throw PermissionDeniedException, 
StaleEntryAccessException and NameNotFoundException 

The convention for a Resource-specific data (RSD) array is that it consists of a 
sequence of pairs- the first element of each pair is a string used to tag the second 
element. (This is represented in an ESMap, for example in the return from 
getPublicRSD). 

Most of the methods in a MetaResource are for setting or getting the fields of its 
Resource metadata. Some aspects of these methods warrant explanation: 

The unregister method removes (unregisters) the Resource, resource, from 
the Repository. This removes ResourceDescription and 
ResourceSpecif icat ion; no more messages can be sent to the Resource after 
this operation. 

The setResourceOwner method sets the owner of the Resource, resource, to 
the ESName of the calling Client s Protection Domain. 

The setResourceProxy and getResourceProxy methods set and get the 
Resource Handler. 

There is no method for setting the Resource Contract, because this cannot be 
changed once the Resource has been registered. 

The method getQuota ( ) returns the total charge in bytes to the owner s quota due 
to that Resource. 
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The methods getMetadataMask and setMetadataMask are used for getting and 
setting the operations for which security is disabled for a particular Resource's 
metadata: anybody can invoke the methods listed in this mask to manipulate the 
particular Resource s metadata. The methods getResourceMask and 
setResourceMask perform the analogous function for the operations supported b 
the Resource itself. 



The user Interface 

This is not implemented in the current release 

interface Userlnterf ace { 
public String getDescription ( ) 

throws PermissionDeniedException, NameNotFoundException; 

public AttributePropertySet getProperties ( ) 

throws PermissionDeniedException, NameNotFoundException; 

public void mutateProperties (AttributePropertySet props) 
throws PermissionDeniedException, NameNotFoundException; 



3 Vocabulary 

See Chapter 3, "Resource Data, Searches & Vocabularies". 



Appendix: Method Names 

In messages sent to Core-managed Resources (see Chapter 6, Xommunication ) 
the method is identified by a string. The following strings are used. 

AccountManagerlnterf ace 
PF REGISTERUSER 
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PF_UNHEGISTERUSER 

PF_AXJTHENTI CATEUS ER 

PF_GETUSERPROFILE 

PF_SETUSERPROFILE 

PF_GETALLUSERS 

PF_ADDDESCRIPTION 

Connect ionManagerlnterf ace 

OPENCONNECTION 

GETCONNECTIONS 

CLOSECONNECTION 

CLOSECONNECTIONFROMREMOTE 

CoreManagement Interface 
PING 

GETCLIENTCONNECTIONS 

STOPSERVINGOUTBOX 

STOPSERVINGINBOX 

STARTS ERVINGOUTBOX 

STARTSERVINGINBOX 

REMOVEPROTECTIONDOMAIN 

DENYNEWCLIENTSESSIONS 

ACCEPTNEWCLIENTSESSIONS 

GETTOTALMEMORY 

GETFREEMEMORY 

START_JVM_GC 

STOP_JVM_GC 

SET_JVM_GC_INTERVAL 

GET_JVM_GC_INTERVAL 

I S_ JVM_GC_RUNNING 

START_SCAVENGER 

S TOP_S CAVENGER 

GET_S CAVENGER_S TATS 

SET__NUM_STATS 

Finderlnterf ace 

FIND 

FINDNEXT 

MailboxInterf ace 

ISCONNECTED 

CONNECT 

DISCONNECT 

RECONNECT 

ManagedServicelntf (implemented by Core management resource) 
GETNAME 
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GETDESCRIPTION 

GETOWNER 

GETUPTIME 

GETVERSION 

GETERRORCOND I T I ON 

GETSTATICINFO 

COLDRESET 

WARMRESET 

START 

STOP 

SHUTDOWN 

REMOVE 

GETSTATE 

GETVARIABLEENTRIES 

GETVARIABLENAMES 

GETVARIABLEENTRY 

SETVARIABLE 

GETRESOURCEENTRIES 

GETRESOURCENAMES 

GETRESOURCEENTRY 

SETRESOURCE 

NameFramelnterface 

ISBOUND 

BIND 

REBIND 

UNBIND 

RENAME 

COPY 

ADD 

SUBTRACT 
LISTNAMES 
LISTBINDINGS 
NEW_SUB_FRAME 

Protect ionDomainlnterf ace 

SWITCHPD 

GETDEFAULTFRAME 

SETDEFAULTFRAME 

GETQUOTAINFO 

SETQUOTA 

NEW_PROTECTION_DOMAIN 

RemoteResourceManagerlnterface 

EXPORTRESOURCE 

IMPORTRESOURCEFROMMSG 
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IMPORTRESOURCE 

EXPORTRESOURCEFROMMSG 

XJNEXPORTRESOURCE 

UNEXPORTRESOURCEFROMMSG 

UPDATEEXPORTEDRESOURCE 

UPDATEEXPORTEDRESOURCEFROMMSG 

UPDATEIMPORTEDRESOURCE 

UPDATE IMPORTEDRESOURCEFROMMSG 

EXPORTONCONNECTING 

RepositoryViewInterf ace 

ADD 

REMOVE 

CONTAINS 

CLEAR 

ADD_ELOOKUP 
REMOVE_ELOOKaP 

ResourceContract Interface 
REGI STERRESOURCE 
GE TVOCABULAR I ES 

ResourceFactorylnterf ace 
REGISTER_RESOURCE 

ResourceManipulationlnterf ace 

UNREGISTER 

GETESUID 

SETRESOURCEOWNER 

GETRESOURCEOWNER 

GETRESOURCEPROXY 

SETRESOXJRCEPROXy 

GETRESOURCECONTRACT 

GETPUBLICRSD 

SETPUBLICRSD 

GETPRIVATERSD 

SETPRIVATERSD 

GETRESOURCEDESCRIPTION 

SETRESOURCEDESCRIPTION 

GETEVENTCONTROL 

SETEVENTCONTROIi 

I S EXPORTEDB YVALUE 

SETEXPORTTYPE 

GETQUOTA 

GETMETADATAMASK 

SETMETADATAMASK 
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GETRESOURCEMASK 

SETRESOURCEMASK 

GETOWNERPUBL I CKE Y 

S ETOWNERPUBL I CKE Y 

GETSERVICEID 

SETSERVICEID 

IS PERSISTENT 

ISTRANSIENT 

SETTRANSIENT 

SETPERSISTENT 

GETURL 

GETTYPE 

Userlnterface (not implemented in the current release) 

GETDESCRIPTION 

GETPROPERTIES 

MUTATEPROPERTIES 

Vocabularylnterface 

GETDESCRIPTION 

GETPROPERTIES 

MUTATEPROPERTIES 
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Overview 

The basis of e-speak access control is a Public Key Infrastructure (PKI). In the 
remainder of this chapter we assume the reader is familar with the principles of PKI, 
sometimes also known as Public Key Cryptography. There are many texts to which 
the reader can refer [see for example Schneier, Pfleeger, Stallings]. 

All entities in e-speak (users, services, cores etc) are identified by public keys. To 
authenticate an entity we verify it knows the private key corresponding to the given 
public key. No entity should ever intentionally share its private key or give anybody 
access to the private key. 

The means by which a private key is protected is implementation dependent: not 
part of the architecture. It is very important that the private key is held securely, so 
it is not unintentionally made available to others. In the default implementation the 
private key is encapsulated inside a Private Security Environment (PSE) object, 
described below. 

Any entity can create a key-pair. Provided the private key is kept secret, the key-pair 
will be unique to that entity. However, having a key-pair gives you no power in the 
system. It is necessary also to have Certificates stating the access rights issued to 
your public key. 

To decide whether to honor an incoming request a service must decide if the 
accompanying certificate (or certificates) grant access rights for the request. 
Before that, it verifies that the sender of the request knows the private key 
corresponding to the public key in the certificate to which the access rights have 
been given (formally this is the Subject of the certificate). It does this by a 
cryptographic protocol described in Chapter 6, "Communication" . 
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Finally before honoring the request, the service must verify that it trusts whoever 
issued the certificate. It does this by verifying that the certificate has been signed by 
an entity that it trusts. 

Comparison with X,509 Certificates 

The most common use of certificates is in X.509 based infrastructures to link an 
entity's name to its public key (technically the X.509 Distinguished Name) . This is 
how certificates are used in the web. A drawback is that, typically, having used the 
certificate to verify the name, a service needs to consult an authorization database 
to determine the access to be granted. 

E-speak certificates are more general tiian this. They are signed (authenticated 
statements) linking a public key to a Name or a Tag. (Certificates linking a Name to 
another Name also exist, and are described below,) The word "tag" distinguishes the 
field concerned from an X.509 "attribute", whose function is broadly similar. A Tag 
typically states an access right. Thus to make an access control decision a service 
does the following: 

• Examines the tag in the certificate to see if it grants access 

• Checks the entity making the request knows the corresponding private key 

• Verifies the certificate has been issued (is signed by) an entity it trusts 

X.509 name certificates are issued by entities called Certificate Authorities. To 
avoid confusion with this, in e-speak we refer to entities issuing certificates as 
Issuers, E-speak Issuers can issue either Name or Attribute certificates. 

Another feature in e-speak not found in X.509 is that it implements a split trust 
model. An entity does not have to trust all Issuers equally. It need not trust any given 
Issuer at all. Those it does trust, it may only trust to issue certificates granting 
access to a subset of its operations. 

Conversely, issuing certificates in e-speak is not a reserved prerogative: anyone can 
do it. Whether or not the certificate will grant access to any Resource depends on 
whether the Resource Handler trusts the Issuer for the service in question. The list 
of which Issuers are trusted for what is called Trust Assumptions. This is discussed 
later in this chapter. 
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Derivation from SPKI 

E-speak implements the Simple Public Key Infrastructure (or SPKI) [see RFC 2692- 
2693[, In addition to the properties already described, SPKI specifies a structure 
and set of operations on Tag and Name certificates. These are used to parse and 
process the certificates when making access control decisions. The processing and 
access control is discussed later in this chapter. Certain tags (e-speak tags) are 
defined that will be checked explicitly by the e-speak infrastructure before an 
access is authorized. However, applications can choose to use any syntactically 
valid SPKI tag. E-speak will check that certificates containing such tags are valid, 
but will not use them for an access control decision. The application will have to 
interpret these non e-speak tags when making access control decisions. Core 
managed Resources will ignore non e-speak tags. 

Certificate Management 

The process by which an Issuer decides to issue a certificate granting access rights 
to an entity is implementation dependent and therefore not part of the architecture. 
The general process would be for entities to register either with some Issuer or with 
a separate Registration Authority (RA). For registration the entity may need to 
provide credentials such as credit card number, social security number, bank 
details, employee ID, user id., and full name. Once the registering body is satisfied 
it wdll issue a certificate, or give instructions for issue. The registering body may be 
fully automated, or may queue registrations for human inspection. 

A given entity may have several certificates that have been issued to it. If no strategy 
is adopted to structure and manage certificate issuing then there may be very large 
numbers of certificates required. Administrators and operators would find it 
difficult to run e-speak systems, and operations such as access revocation would be 
extremely hard. Hence we discuss and recommend certain strategies for certificate 
management. These are based around familiar concepts such as user-groups (or 
roles) , found in several common operating systems. These are not part of the 
architecture. The management strategy practised must reflect the business 
requirements of the deploying organization. 
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Anybody can create a key-pair in e-speak and then register to get an Issuer to issue 
certificates to the public key. There is no notion of a centralized, all powerful 
trusted Certificate Authority. Instead entities choose which Issuers they trust for 
what. Authentication in e-speak relies on proof of knowledge of the private key: 
there is no centralized authentication service. Hence the e-speak security 
architecture is a global fully distributed and single sign-on. 



Example of certificate-based Security (Informational) 

Consider the diagram below. Two large ".com" companies are accessing a portal to 
use services provided by the portal. For simplicity we have shown only 3 services. 




The data held by the services may be sensitive, so both companies would like to be 
sure that their employees are accessing the correct portal and services. In addition, 
having made arrangements for access to the portal (and paid fees) , both companies 
might prefer to be responsible for managing their own lists of employees and 
control who can access the portal's services. 

From the portaFs point of view, it probably only wants to deliver services to paying 
customers and only to deliver those services that each customer has paid for. 
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Suppose C0_1 has done a deal with the portal to access services A, B and C, and 
C0_2 has done a deal to access service A and C only. Lets further suppose that C0_1 
and C0_2 are each running an Issuer , called Issuerl and IssuerZ respectively. The 
portal configures A and C to trust both Issuerl and Issuer2; it configures B to trust 
Issuerl only. Then C0_1 and C0_2 can issue certificates to each of their employees. 
CO_rs certificates will be honored at A, B and C, but C0_2 certificates will only be 
honored at A and C. 

Each time a service sees a certificate from either company that grants access, it 
increments the bill for that company. This leaves each company in control of who 
among its employees gets access to the services for which it has paid. Each 
company is in control of revocation (e.g. if the employee leaves). In addition the 
portal can immediately revoke access to an entire company, by removing the 
company's Issuer from the list of trusted Issuers, 

Each company may want to make sure that their employees are accessing only 
genuine services. To do so CO_rs Issuer issues a Tag certificate binding each of 
service A, B and C s public keys to a tag such as : "C0_1 approved". It must then 
ensure that its employees configure their clients to check for this tag before 
accessing the service. Similarly C0_2's Issuer issues a Tag certificate to services A 
and C conferring an attribute that is meaningful to C0_2, 

Note that this requires very little authorization data to be held and managed by the 
portal. It only needs to remember the public keys of C0_1 and C0_2's Issuer. If 
access control were based on authenticating a name and mapping accesses to that 
name, then the portal would have to keep a list of all employees in each company 
that can access any of the services, and which accesses are allowed for each name 
- much more data to manage and maintain. 
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The informal structure of an authorization certificate is: 

Certificate header: a constant field starting " (cert " 
Issuer: the public key of the Issuer 

Subject: the public key or the name of the entity granted the 
certificate 

An optional "delegation" field 

Tag: Details of what is authorized 

Optional validity qualification and comment. 

In this structure, it is the tag that requires most attention by client applications. 



Tags 

As e-speak implements SPKI, any valid SPKI tag can appear in a certificate. The 
BNF for SPKI is given in the SPKI BNF Format seOxon, In this section we give some 
example SPKI tags that can appear in certificates and explain the BNF for a tag. 

E-speak defmes a set of standard tabs (see "E-speak Authorization Tags" on page 
87) , that will be checked automatically by the infrastructure. The examples given 
in this section are not standard e-speak tags, so they would have to be checked 
explicitly by the application. 

An SPKI tag is an S-expression, that is a list enclosed in matching and ")", 
The BNF for a tag is: 

<tag> = "tag" <tag-expr>* ")" ; 

<tag-and> = " (*' "and" <tag-expr>+ ")" ; 

<tag-expr> = <byte-string> | <tag-simple> 

<tag-prefix> | <tag-range> 

<tag-set> | <tag-and> 

<tag-star> ; 

<tag-simple> = "(" <byte-string> <tag-expr>* ")" ; 
<tag-prefix> "(" "prefix" <byte-string> ")" / 

<tag-range> = "(" "*" "range" <range-ordering> <low-lim>? <up- 
lim>? ") " ; ^ 
<tag-set> = "(" "set" <tag-expr>* ")" ; 

<tag-star> = "(" ")" ; 
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<tag-and> = "*" "and" <tag-expr>+ ")" ; 3- 

<range-ordering>= "alpha" I "numeric" I "time" | "binary" I 
"date" ; I I I 

<up-lim> = <lte> <byte-string> ; 
<low-lim> = <gte> <byte-string> ; 
<lte> = "1" I "le" ; 
<gte> = "g" | "ge" ; 

A tag is a list of lists, with each list denoted by brackets. In its simplest form (tag- 
simple), a tag is simply composed of byte-strings. The access control machinery 
must interpret the meaning of the tag when making an access control decision. The 
following examples are adapted from SPKI examples previously published as 
Internet drafts. An example form for tags applying to a file system is: 

(tag (files <pathname> <access> )) 
An instance of such a tag is: 

(tag (files //ftp. espeak.net/pub/EspeakArch.pdf read)) 
A client presenting a certificate containing the above tag is allowed read access to 
EspeakArch.pdf (assuming authentication was successful). 

<tag-set> field 

Groups of permissions can be granted using the "tag-set" form: 

(tag (files //ftp. espeak.net/pub/EspeakArch.pdf (* set read 
write) ) 

This grants read and vmte acess to the file. 
<tag-prefix> field 

A set of permissions having a common prefix can be granted using the "tag-prefix" 
form: 

(tag (files (* prefix //f tp . e speak .net /pub/ ) (* set read write)) 
This grants read and write access to any file under the pub directory. 

<tag-star> field 

The "tag-star" form stands for the set of all valid s-expressions and byte strings. 
1 The <tag-and> field is an e-speak specific extension to SPKI. 
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(tag (files (* prefix //ftp .espeak.net/pub/ ) (*) ) 
The above tag grants all permissions on all files under pub. 

(tag (files (*) (*) ) 
Note that trailing "(*)" can be omitted. So the above is equivalent to: 

(tag (files)) 

The two last tags both grant all permissions on all files anywhere, 
(tag (*)) 

The above grants all permissions on anything. This might look as though it is 
conferring a lot of power. However, e-speak has a split trust model: the issuer of 
the certificate containing this tag might only be trusted by a single Resource. 

<tag-and> field 

The "tag-and" form is not used in writing a certificate. It expresses the 
autiiorizations conferred by the set of tags in the following expression. This is 
analagous to a set-intersection operation: the authorization resulting from a "tag- 
and" form will be that satisfying each and every one of the following tags. So it is 
more restrictive than that of any of the tags on its ovm.This form is used internally 
when authorization depends on more than one certificate. The process is described 
under Tag Intersection. 

<tag-range> field 

The "tag-range" form stands for the set of all byte strings lexically (or numerically) 
between the two limits. The ordering parameter (alpha, numeric, time, binary, date) 
specifies the kind of strings allowed. For example, the following tag indicates the 
authorization to issue purchase orders whose value is less than $5000. 

(tag (purchaseOrder (* range numeric le 5000 ))) 
The following indicates a salary between $50,000 and $100,000 

(tag (salary (* range numeric ge 50000 le 100000))) 
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E-speak Authorization Tags 

E-speak tags are valid SPKI tags that will be checked by the infrastructure. For core- 
managed Resources the e-speak core will check that a valid certificate is presented 
containing a tag that authorizes the operation. For non-core-managed Resources, it 
is assumed that the resource handler will check there is a valid certificate 
containing a tag that authorizes the operation. However, the e-speak core cannot 
enforce this; the resource handler is responsible for Resource security, 

E-speak tags that authorize access to services have the following form: 

(tag (net .espeak. method <interface> <Tnethod> <serviceld>) ) 
The following tag authorizes the "stop" operation in the 
serviceManagementlnterface for the identified Resource, 

(tag (net .espeak. met hod ServiceManagementlnterface stop 
xxxxyyyyzzzz) ) 

The forms tag-star, tag-prefix, tag-set and tag-range can all be used within an e- 
speak tag. So the following tag authorizes operations on the ServiceManagement 
interface in two different Resources, 

(tag (* set (net .espeak. method Se3rviceManagementInterf ace stop 
xxxxyyyyzzzz) 

(net .espeak. method ServiceManagementlnterface (* set stop start) 
aaaabbbbbccccc) ) ) 

The long strings at the end represent the Serviceld, described below. 

The foUov^ng form authorizes every method on every ServiceManagementlnterface 
on Resources that trust the issuer. 

(tag (net .espeak. method ServiceManagementlnterface (*) (*) )) 
Or equivalently: 

(tag (net .espeak. method ServiceManagementlnterface )) 

The following authorizes any method within the given interfaces (core managed 
Resources) on any object: 

(tag ( 
(net . espeak. method 
(* set 

ResourceFactorylnterface 
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ResourceManipulationlnterface 
ManagedServicelnterface 
CoreManagement Interface 
NameFramelnterf ace 
) 

) 

) 

Lets assume we have an interface called Tile" and the servicelD is set to a notional 
path name (a non default value) . The follovmig tag authorizes the read operation on 
all files below the pub directory. 

{tag (net. espeak. method file read (* prefix es.espeak.net/pub/ 

If serviceld's are set to ordered numerical or alphabetical values, then the tag-range 
form may be useful in the <serviceld> portion of a tag. 

Currentiy we have only defined e-speak tags for the Network Object Model. This 
assumes a set of services with one or more interfaces, each interface containing one 
or more methods. The programming of J-ESI and the interaction with core- 
managed Resources follow this model. However, e-speak can support other 
programming models: an XML document exchange model and a direct messaging 
model have both been implemented. The tags used by these models are part of the 
programming models. There are not part of the core architecture, since the core 
does not need to interpret them: the resource handlers do it. 



Service Identity 

The serviceld field in the Resource specification (see Chapter 3, "Resource Data, 
Searches & Vocabularies") can contain any valid SPKI tag-expression, defined as a 
"tag-expr" in the BNF (see "SPKI BNF Formats" on page 109). This tag-expression 
can be set by anybody with a certificate, from an Issuer trusted by the 
MetaResource, authorizing setServiceld in the MetaResource. The serviceld field is 
delivered to the resource handler widi each message for the Resource. 

The service identity is used by the resource handler when verifying standard e- 
speak tags (see "Verifying tags and tag intersection" on page 100). 
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Default Serviceld 

A default assignment is made by the core when it encounters a standard e-speak 
authorization tag without an authorized service id. The format is: 

<serviceld> = "(" "net . espeak. service" <service class> <service 
name> <unique id> ")" 

<service class> is set to the first available value of: 

L) The name attribute in the Resource specification contract, if any. 

2. ) The contract type, if any. 

3. ) A 64-bit random no. if neither of the above exists. 
<service name> is set to: 

1. ) The ' "name" in the Resource description 

2. ) A 64-bit random no., if 1) is not found. 
<unique id> is a 64-bit random no. 

A secure random number generator should be used, so that the probability of 
accidental authorization when the default has been used will be infinitesimal.. 

Advantages of Servicelds 

The serviceld is intended for use by applications to identify services without using 
the Resource name or access path (ESNames). This decouples authorization from 
resource naming and has several advantages: 

• Service ESNames can be changed without affecting authorization 

• Authorization can be revoked by changing a service's identity, without 
changing its ESName 

• In a replicated service replicas can all have the same identity 

• Tag patterns (the "tag-star" form) can be used effectively, limiting the number 
of certificates issued 

None of this is possible using ESName for service identity. 
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Protection of Servicelds 

Service identity plays a crucial role in authorizing access to a service (see "Verifying 
tags and tag intersection" on page 100). It is essential that the setServicelD 
operation source is protected, so that a valid certificate is required to invoke it. 



Names: Userids, Groups.... 

E-speak also supports SPKI name certificates, of two types. In the first place, an 
Issuer can issue a certificate that binds a public key to a name. This has similarities 
to X.509 certificates which bind a public key to an X.509 Distinguished Name. (A 
Distinguished Name is a name in a special format, distinguishing it globally from 
any other name.) 

SPKI name certificates do not restrict the syntax of the name, other than requiring 
them to be a bytestring. Instead, names are scoped by the pubhc key of the issuer. 
Referring back to our example (see "Example of certificate-based Security 
(Informational)" on page 82), both C0_1 and C0_2 could have an employee named 
John Doe. Assuming each company had an Issuer that issued name certificates 
binding these names to public keys, the fully qualified name for each John Doe is: 

Public key of C0_1 issuer: John Doe 
Public key of C0_2 issuer: John Doe 

Hence the portal (and anybody else) would have no difficulty distinguishing 
between the two insteinces of John Doe. 

The second type of name certificate binds a name to a name. For example we might 
want to bind John Doe to the name "users". This kind of certificate confers 
membership of the group "users" on the userid John Doe. It can be used to build a 
role- or group- based security model, such as represented below (see "Managing 
certificates (informational)" on page 106). 
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Public keys Names Group name Services 

Name- Name- Authorization 

KEY: Public Key Name certificate 
certificate certificate 

The algorithm which relates a public key to an authorization in this case is 
described below (see "Name Reduction" on page 97). [See also RFC 2693[ 



Certificate Structure 

The two kinds of certificates in e-speak are Authorization Certificates that bind a 
tag to a public key or a name and Name Certificates that bind a name to a public key 
or a name. The following sections describe and explain the BNF which specify these 
types. 

Some general features of the specification are: 

Nearly every field begins with its name as a literal string. 

* is used to mean "0 or more cases of the preceding field" 

* is also used to mean "anything valid" in the tag-star field described above 
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-h means "one or more instances of the preceding field" 
? means the preceding field is optional 
"uris" means a field with one or more URI's. 

The full SPKI BNF is given at the end of this Chapter (see "SPKI BNF Formats" on 
page 109). 

Authorization Certificates 

The format for an authorization certificate is: 

<cert> = "cert" <version>? <cert-display>? 

<issuer> <issuer-inf o>? 

<subject> <subject-info>? 

<deleg>? 

<tag> 

<valid>? 

<comment>? ")" ; 

The optional <version> field defines the <version> of the certificate. The optional 
<cert-display> field is designed to provide hints for display. Neither of these fields 
is used in the current version of e-speak; the parser will ignore them. 

Issuer field 

The <issuer> field is the public key of the Issuer issuing the certificate; it is defined 
as follows, 

<issuer> = "(" "issuer" <principal> ")" ; 
<principal> = <public-key> | <hash-of -key> ; 
<hash-of-key> = <hash> ; 

<hash> = "(" "hash" <hash-alg-name> <hash-value><uris>? ; 
<hash-alg-name> = "mdS" | "shal" ) <uri> ; 
<hash-value> = <byte-string> ; 

<public-key> = "(" "public-key" <pub-sig-alg-id> <s-expr>* 
<uris>? " ) " ; 

<pub-sig-alg-id>= "rsa-pkcsl-mdS" | "rsa-pkcsl-shal" | "rsa- 
pkcsl" I "dsa-shal" | <uri> ; 

The <issuer-info> field is intended in SPKI to provide a list of one or more URIs for 
certificates from which the Issuer derives its authority to issue the certificate. This 
is to support delegation: one Issuer may issue a certificate to another Issuer with 
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the delegation field present. (It is the literal "propagate".) Suppose a service trusts 
the first Issuer directly, and not the second Issuer. If a client presents a certificate 
issued fi^om the second Issuer, the service will need to see the delegate certificate 
conferring the privilege on the second Issuer before it authorizes access. The URIs 
would specify the location of delegate certificates. This is not used in the current 
version of e-speak. Instead, the required supporting certificates are obtained during 
the Session Layer handshake (see Chapter 6, Communication^), The parser will 
ignore this field. 

The "hash-alg-name" and "pub-sig-alg-id" fields identify algorithms used for hashing 
and for signature verification - usually the literal abbreviated algorithm names 
given. The "uri" alternative in each case could be used to give a URI of some other 
algorithm. 

Subject field 

The <subject> field denotes the entity to which the certificate is issued. 

<subject> = "(" "subject" <siibj-obj> ") " ; 

<subj-obj> = <principal> | <name> | <object-hash> ;2 

<principal> = <public-key> | <has]i-of -key> ; 

<naTne> = <relative-name> | < full -name > ; 

< relative- name > ^ "(" "name" <byte-string>* ")" ; 

<full-name> = "name" <principal> <byte-string>* ; 

The <subject> is either a pubUc key, a name or die hash of an object If the subject 
is a public key, then the entity presenting the certificate must prove possession of 
the corresponding private key before authorization is granted. This uses the 
cryptographic protocols described in Chapter 6, "Communication". 

If the <subject> is a name, then authorization is granted to the entity that has a 
certificate binding that name to its public key (see "Name Certificates" on page 96) . 
Several certificates may be required to prove this. For example the authorization 



2 The definition here departs from SPKI slightly SPKI defines <subj-obj> = <principal> | 
<name> | <object-hash> | <keyholder>; E-speak does not support <keyholder>. If the 
parser encounters a keyholder field, it will throw an exception. Which exception depends 
on the point from which it is invoked. One of die e-speak exceptions specified in Chapter 
7, "Exceptions" will be thrown. 
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certificate may be issued to a name such as "users". The name "users" may be 
conferred on another name "John Doe", a real world person. So to get authorization 
three certificates are needed: 

• A certificate binding John Doe's public key to his name 

• A certificate binding John Doe to the name "users" 

• A certificate granting the authorization to "users" 

John Doe needs to prove possession of the private key corresponding to the public 
key in the first certificate using the protocols described in Chapter 6, 
"Communication .The algorithm for name reduction to arrive at the certificate 
binding die name to a key and handling compound names such as <public key: 
"John Doe" "Favorite People"> is described below (see "Name Reduction" on page 
97). ^ ^ 

<relative-nanfie> and <full-name> 

A <relative-name> is assumed to have been issued by the Issuer whose public key 
is in the issuer field. In contrast, a <full-name> is a fully qualified name, explicitly 
scoped by the public key of the Issuer which conferred it. This principle is extended 
for names "issued by" names [see Compound Names below]. The use of qualified 
names allows any Issuer to issue certificates to names that have been issued by any 
other Issuer. 

<object-hash> (Informational) 

An <object-hash> is intended for the issue of authorization certificates to entities 
such as files and executables. The tag in such a certificate might describe a property 
of the file or the executable. This is not used in the current version of e-speak. The 
parser will ignore the field. 

<subject-info> (Informational) 

The optional <subject-info?> field is defined as follows. 

<subject-info> = "(" "subject-info" <uris> ; 
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The intent of this field is to provide a list of URIs that provide information about the 
subject. For example if the subject is a hash of a key, it might provide the location 
of the key being hashed. If the subject is a name, it might provide the location of the 
name certificates. This field is not used in the current version of e-speak. The parser 
will ignore it. 

Delegation field 

The optional <deleg> field is defined as follows. 

<deleg> = "{" "propagate" ; 

If this field is included in a certificate, then the subject is authorized to delegate the 
authorization specified in the certificates tag. The subject does this by issuing 
certificates containing the tag, or a subset of the tag's privileges. This is discussed 
further imder Delegation, 

Validity field 

The optional <valid> field is defined as follows. 

<valid> = <valid-basic> <online-test>* <restrictions> ; 
<valid-basic> = <not-bef ore>? <not-after>? ; 
<not-after> = "(" "not-after" <date> ") " ; 
<not-before> = "(» "not-before" <date> ") " ; 
<date> - <byte-string> ; 

If the valid field is missing, the certificate is assumed to be valid without constraints. 
The fields <online-test> and <restrictions> defined in [ Working Drafti are not 
supported in the current version of e-speak; the parser will ignore them. The <valid- 
basio field is used to support time-based revocation, as described under 
Certificate Revocation. 

A <date> field is an ASCII byte string of the form: 

YYyy-MM-DD_HH : mm : SS 

This is always UTC. For example, "1997-07-26_23:15:10" is a valid date. So is "2001- 
01-01_00:00:00". "MM" is a two digit integer in the range 1 to 12; "mm" and "SS" are 
two-digit integers in the range 0 to 59. 

The optional comment field is defined as follows: 
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<coTnment> = "(" "comment" <byte-string> ; 

Anything is this field is intended to provide information to humans. It is ignored by 
e-speak. 

Name Certificates 

The format for name certificates is: 

<name-cert> ^ " (" "cert" <version>? <cert-display>? 

<issuer-name> <issuer-inf o>? 

<subject> < subject -info? 

<valid> < comment >? ")" ; 
<issuer-name> = "(" "issuer" "(" "name" <principal> <byte- 
string> ") " ") " ; 

<principal> = <public-key> | <hash-of -key> ; 

The characteristic feature of a name certificate is the the <issuer-name> field. This 
defines the issuer of the certificate plus the name of the certificate holder. "Issuer- 
name" does not mean "name of issuer". The byte-string in this field is the certificate 
holder's name, and the <principal> is the issuer s public key, or a hash of it. In the 
latter case, there may be a following field containing a URI of the full key, but this 
is not currently used or supported in e-speak. 

Public Keys 

An example of a public key is: 

(public -key 

{rsa-pkcsl-mdS 
(e #03#) 
(n 

|ANHCG85jXFGmicr3MGPj53FYYSYlaWAue6PKnpFErHhKMJa4HrK4WSKT0 
YTTlapRznnELD2D7lWd3Q8PD01yilNJpNzMkxQVHrrAnIQoczeOZui2/yy 

The long string between "|" 's is a number encoded in base64 notation for relative 
brevity. This is a feature of BNF advanced syntax [see BNF Notation below]. 

Such items may have to be written in certificates, but in the following text, we use 
"PK XXX" as an abbreviation for "XXX s public key". 
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Example 

Taking the example (see "Names: Userids, Groups,..," on page 90), the following 
certificate could be issued by CO_rs Issuer. 

(cert Certificate A 

(issuer ( name (PK CO 1) "John Doe") ) 
(subject (PK John Doe) ) 
(not-after "2001-01-01 00:00:00") 

) 

The underlining is referred to in the next paragraph. 

Name Reduction 

The objective of name reduction is to reduce the name that appears in a subject field 
to a single public key, a <principal>. Name reduction replaces the name in a subject 
field, by rewriting it with the subject field from the corresponding name certificate. 
It uses the fact that a fiiUy qualified name in a subject field has the same format as 
<principal> <byte-string> in an issuer-name field. For example, given Certificate 
A above, suppose there is an authorization certificate: 

(cert 

Certificate B 

(issuer PK X) 

(subject (name (PK CO 1) "John Doe")) 
^ (tag (net .espeak. method CoreManagementlnterf ace )) 

The two underlined fields being the same, we can replace <subject> in B by 
<subject> in A, giving certificate C: 

(cert 

Certificate C 

(issuer PK X) 

(subject (PK John Doe)) 

(tag (net .espeak. method CoreManagementlnterf ace )) 
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Suppose an entity "Editor" issues a name certificate to "Foreign Desk"; and this 
entity in turn issues one to "Paris Correspondent". Each will have PK holder as its 
Subject. An authorization certificate could be made out as follows: 

(cert 

(issuer PK Accounts) 
(subject (name (PK Editor) "Foreign Desk" "Paris Correpondent " 
^ (tag (Dinner_Expenses (*range le 200) (currency FF) ) ^ 

The subject field is a Compound Name. Accessing the name certificates implied in the 
subject field from left to right, we replace this field successively by: 

(subject (name (PK Foreign Desk) "Paris Correspondent) 
(subject (PK Paris Correspondent) ) 

- yielding a certificate which can be authenticated. 

Name reduction is defined formally as part of the tuple reduction rules in [SPKF 
theory, RFC 2693[. This also includes an algorithm for combining validity fields. If 
the validity fields are dates (as in the current e-speak implementation), then 
informally we take the latest <not-before> date and the earliest <not-after> date. If 
the <not-after> date obtained in this way is before the <not-before> date, then the 
reduction has failed. 

Wire format for certificates 

The "on-the-wire" format for certificates is the BNF Canonical Syntax (see "SPKI 
BNF Formats" on page 109). 



Delegation 

E-speak supports SPKI delegation. If an Issuer is not trusted directly by the enUty 
checking the authorization, its certificates cannot effectively authorize more than 
the delegate certificate authorizes. The SPKI certificate reduction rules [see 

3 Not an e-speak tag. 
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RFC2693 ' Alntersec^ describe formally how this is enforced. Informally, it is done 
by intersecting the authorizations specified by all tags in the delegation chain, and 
taking the smallest validity period as decribed in the Name Reduction section. 

Consider the following certificate. 

(cert 
(issuer PK X) 
{subject PK Y) 
(propagate) 

(tag (net .espeak.method CoreManagementlnterf ace )) 
(not-after "2 000-10-01_00 : 00 : 00 " ) 

Suppose Y now issues a certifcate to Z as follows. 

(cert 
(issuer PK Y) 
(subject PK Z) 
(tag (net .espeak.method )) 
(not-after "2001-01-01 00:00:00") 

) 

Here Y is attempting to authorize more, for longer than was contained in the 
certificate issued to it by X, 

Suppose an entity, checking that Z is authorized, trusts X directly, but not Y. The 
two certificates above form the delegate chain by which Z is obtaining its power. 
The entity intersects the two tags (as described below) , combines the validity times 
(as described above) and rewrites the issuer field according to the reduction rules 
described in [RFC2693i to get the following certificate. 

(cert 
(issuer PK X) 
(subject PK Z) 

(tag (ne t . espeak . method CoreManagementlnterf ace ) ) 
(not-after "2000-10-01 00:00:00") 

) 

Hence it is not possible for Y's certificate to authorize more for longer than the 
original certificate granted to Y by X, fi*om entities which don't trust Y directly. 
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Verifying tags and tag intersection 

Tag verification is the process of determining whether the set of certificates 
presented contain the required authorization. SPKI tags define sets of 
authorizations. For example the following tag authorizes all methods on all 
instances of the CoreManagementlnterface. 

(tag (net .espeak. method CoreManagementlnterface )) 

So the above tag "contains" the following tag (xxxxyyyyzzzz is the servicelD). 
( tag (net . espeak . method CoreManagementlnterface ping 

Appending elements to the end of a tag reduces the set of authorizations specified. 
So: 

(tag (net .espeak. method CoreManagementlnterface ping)) 
specifies less than 

(tag (net .espeak. method CoreManagementlnterface )) 
In the case of a delegation chain, where the successive certificates authorize: 

1 services A, B, C 

2 services B, C, D 

3 services B, D. E - 

the only service authorized will be B - the only member of the "intersection" of the 
three certificates. 

Implementing Verification 

In e-speak, each time an object receives a request to invoke a method, the security 
infrastructure will check that there is a certificate that contains the tag needed to 
invoke the operation. For Core-managed Resources the security infrastructure is 
contained in the core. For other Resources, it is part of the Resource. The security 
infrastructure is part of the current implementation of J-ESI, and clients can use the 
security infrastructure APFs for their own resource handlers. 
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For example, if an attempt is made by a client to invoke the "ping" operation on a 
CoreManagementlnterface, the infrastructure will check that there is a certificate 
that contains the tag (tag (net.espeak.method CoreManagementlnterface ping 
xxxxyyyyzzzz)), where xxxyyyzzz is the servicelD of the service being invoked. 

For this to work the infrastructure must know the servicelD of the Resource. The 
servicelD is part of the Resource s metadata, and the core presents the servicelD 
with each request. It is trusted to present the correct servicelD. 

For a certificate to authorize an operation we also have to check that the certificate 
is issued by somebody trusted to authorize the particular operation on the 
particular Resource [see Trust Assumptions section]. This means checking the 
public key of the issuer and the signature of the certificate. It is done automatically 
by the security infrastructure. 

Authorization certificates can be issued to names as well as public keys. If a 
certificate issued to a name is presented that authorizes the operation, the name 
must be reduced to the public key of the invoker, as described in the Name 
Reduction section. The invoker s public key will be authenticated by the protocols 
described in Chapter 6, Xommunication". 

Authentication of Services (Informational) 

In addition to the e-speak tags specified in the E-speak Authorization Tagssection, 
a client or service can ask for application-specific tags to be checked, by invoking 
the security infrastructure APIs. Since no e-speak tags are specified for servers to 
present to clients, any authentication of the service by the client will be application- 
specific. For example a client might check for a tag identifying the Id, of a service, 
such as: 

(tag (net.espeak.serviceID xxxxyyyyzzzz)) 

This means that the server will have to get a certificate issued to it containing this 
tag. See the Certificate Issuers and Registration section below. 

The security APIs for checking application-specific tags are outside the 
architecture. They are application-specific, and no application-specific tags are 
supported for core-managed Resources. 
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Disabling Security 

This is done by sets of tags called "masks" in the ResourceSpecification (see 
Chapter 3, Resource Data, Searches & Vocabularies". Two masks occur in the 
ResourceDescription: 

The Metadata mask, which disables security on methods in the 
ResourceManipulationlnterface. 

The ResourceMask, which disables security on methods in an interface of the 
Resource being specified. 

The basic method tag format is 

(net .espeak. method <interface name> <method name>) 
In the metadataMask the interface name is the core interface being specified, and 
the method name is the operation in that interface. For metadata this will be be the 
ResourceManipulationlnterface, and the method name one of its methods. For the 
resourceMask the interface name will be one of the interfaces supported by the 
Resource. 

In the resource mask for an external Resource the interface name is the fully- 
qualified name of the interface class. For a Core-managed Resource, the interface 
name is not qualified, so we just have "NameFramelnterface'' and 
"ProtectionDomainlnterface" etc. The method name is the name of the method in 
the interface, plus the concatenated argument types. This allows overloaded 
methods to be distinguished. 

The metadata mask is used by the in-core metaresource when performing metadata 
operations. The resource mask is passed to the service handler by the core for the 
service handler to use when performing operations on the service itself. 

The masks are completely general tags, so the mask tag itself, or any of its fields, 
may use the tag matching features such as sets, prefixes and ranges. The interface 
and method names, for example, do not have to be string literals, they can be sets 
or prefixes. 

This tag masks method foo in interface net.espeak.examples.ExampleIntf: 
(net. espeak. method net .espeak. examples. Examplelntf foo) 
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This tag masks method foo in interface netespeak.examples.Examplelntf and 
method bar in interface net,espeak.examples.Example2Intf 

(net . espeak . method ( * set 

(net . espeak . examples . Examplelntf foo) 

(net .espeak. examples. Example2Intf bar) 

This tag masks all methods beginning with foo: 

(net .espeak. method net . espeak . examples . Examplelntf (* prefix 
foo) ) 

This tag masks methods foo and bar: 

(net. espeak. method net .espeak. examples .Examplelntf (* set foo 
bar) ) 

To mask methods with prefix foo or bar: 

(net . espeak . method net . espeak . examples . Examplelntf 
(* set (* prefix foo) (* prefix bar))) 

To mask all methods in the interface: 

(net .espeak. method net .espeak. examples .Examplelntf ) 
This is equivalent to 

(net . espeak . method net . espeak . examples . Examplelntf ( * ) ) 
since missing trailing elements match anything. 
To mask methods foo in InterfaceA and bar in InterfaceB: 

(* set (net .espeak. method InterfaceA foo) 
(net .espeak. method InterfaceB bar)) 

To mask all methods: 

(net . espeak . method) 
or simply 

{*) 
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Certificate Issuers and Registration (Informational) 

There is no restriction in e-speak on who can issue a certificate. Anything that has 
a public key can do it. A certificate gets its power either from trust in the Issuer, or 
from a delegation chain down from a trusted Issuer. If the issuer is not trusted 
directly by a service and has no delegate certificate, its certificates will not 
authorize access to that service. 

The processes of issuing a certificate and of deciding to issue one are application- 
specific: not part of the architecture. In some applications an entity may have to 
undergo a registration process whereby some real-world characteristics are 
verified (credit card numbers, social security numbers and the like). Registration 
may be fully automated, or it may involve human inspection. 

Service Ids. 

Problems can arise if services have the same service identity, either accidently or 
deliberately. For example, a service might use a fake serviceld and ask someone to 
issue privileges for that serviceld. The issuer would then think it was issuing 
privileges on the fake service, when in fact it was issuing privileges on the real 
service. To avoid these problems, anyone claiming ownership of a serviceld must 
be required to produce a certificate granting it to them. This prevents serviceld 
spoofing. 

Unique service identies can be enforced by all Issuers knowing all previously issued 
service identites, or having the Issuer itself generate and issue a cryptographically 
secure and unique service identity in a certificate, or by relying on the service 
identities generated by e-speak, using a cryptographically secure random-number 
generator. 

Note that sometimes we may want to have the same identity for multiple services. 
For example, the services might be replicated. So, whether service identities are 
required to be unique and how this is enforced is not part of the architecture. 
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Trust Assumptions (Informational) 

The basis for establishing trust assumptions is: 

• Who you trust and for what. 

• The importance of protecting this information from tampering. 

• The need to conceal or to reveal who you trust. 

All this is application specific, and trust assumptions are not part of the e-speak 
core s architecture. 

Trust assumptions define whose certificates will be honored, and the acceptable set 
of tags in each case. Both clients and services may have trust assumptions. Trust 
assumptions do not appear in any of the e-speak protocols (core to core, or client 
to core APIs). 

It may be important for a client or server not to reveal certain trust assumptions, 
containing information of potential use to an attacker. Conversely, a trust 
assumption might need to be broadcast, for example to let potential (paying) 
clients know the Issuer they need to get a certificate from, to access a service. 

It is essential to prevent unauthorized tampering vrith trust assumptions, so that 
attackers cannot add themselves to the list of trusted entities. 

The current implementation uses self-issued certificates to store trust assumptions. 
A certificate is only accepted as a trust assumption if it is self-issued. The format of 
trust assumption certificates in the current implementation of e-speak is exactly 
like that of an authorization certificate. The client or service must distinguish 
between authorization certificates and trust-assumption certificates. This should be 
easy: authorization certificates will be exchanged between two entities as part of 
the message protocols (see Chapter 6, Xommunication**). Trust assumption 
certificates will probably be stored locally on disk. They should in any case be 
separate from authorization certificates. 

The following certificate authorizes the entity Certificatelssuer to issue certificates 
authorizing any method in the CoreManagementlnterface. 

(cert 
(issuer PK self) 
(subject PK Certificatelssuer) 
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(tag (net .espeak. method CoreManagement Interface )) 

) 

The following certificate means the entity trust itself to issue any certificate. 

(cert 
(issuer PK self) 
(subject PK self) 
(tag (* )) 

) 

Note that trust assumptions can use names or public keys as subjects. 



Certificate Revocation 

In the current implementation the only supported means of expressing validity is 
time (the <valid-basic> element). Once a certificate is issued it is valid until it 
expires. 

SPKI supports online tests for validity. Future releases of e-speak will probably do 
the same, and support the principle of a certificate revocation list (CRL). 



Managing certificates (informational) 

The current implementation of e-speak has a Certificate Issuing Service (CI) that 
can be used to issue certificates authorizing access to services that trust it. This CI 
might be used to manage access to a set of services on a set of e-speak cores. Here 
we outline the way in which the CI manages its certificates as a guideline to those 
who may wish to implement their own CI. 

The CI implements a notion of users and groups. When a user registers with the CI, 
this service issues a name certificate binding the user's name (userid) to a public 
key. Thereafter all certificates are issued to the userid rather than the user s public 
key. This means that to revoke all access to a user we need only revoke the 
certificate binding the userid to the public key. 
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The CI also maintains a list of groups analagous to the groups you might find used 
in operating system security architectures (e.g. "users" and "administrator"). An 
operator of the CI can create new groups. To add a user or users to a group, the 
operator selects the userid or userids and group. The CI then issues a name 
certificate to each user, binding the userid name to the group name. 

To issue authorization certificates for a service, the CI needs to know what 
interfaces and methods are available on the service (the client stub is used for this) . 
The CI presents a simple GUI listing the methods for each interface as well as listing 
groups and userids. The operator can select the group or individual user and what 
interfaces or methods they will be allowed to access. The CI issues an authorization 
certificate to the userid or the group. 

Whenever the CI issues a certificate, it records this in its policy database. The policy 
database is used to drive access revocation and certificate renewal 

The CI provides a certificate directory interface from which stored certificates can 
be retrieved. This allows services to see what certificates have been issued to users 
and permits users to retrieve certificates that have been issued to them. 

Revoking and Renewing certificates 

A certificate is valid until it expires. To save having to renew all certificates 
frequentiy, an Issuer might choose a relatively short period of validity when issuing 
name certificates binding a user s name to a public key. Other certificates, 
particularly authorization certficates would have longer periods of validity. 

The policy for certificate renewal, enforced by the CI, is to renew automatically all 
certificates in its policy database as they approach expiry. Renewed certificates can 
be retrieved from the CPs certificate directory. 

If a CI operator revokes access or removes a user, the certificate (s) are removed 
from the policy database immediately. This means the certificates will not be 
renewed and can no longer be retrieved from the directory. Entities that have 
retrieved certificates from the certificate directory may continue to use them until 
they have expired. 

Note that all a user's power is revoked as soon as the certificate binding their name 
to a public key expires. 
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Renewing keys 

The CI supports key renewal by issuing a certificate binding the user's new key to 
the user's name. All other certificates issued to the user will remain valid as they are 
issued to the user's userid (name). The user may have to undergo a process similar 
to registration to convince the CI that the new key is valid. 



Private Security Environments (Informational) 

Private keys must never be shared and so need to be stored securely. How private 
keys are stored is a matter for the ovmer of the key and has no impact on the e-speak 
protocols or APIs used to interact with the core. It is therefore not part of the 
architecture. In the current implementation a PSE or Private Security Environment 
is used. This stores the keys in an encrypted file on a disk. 

The private keys are never revealed to the the application. Instead data is sent to the 
PSE object when it requires signing. The PSE framework has been designed so that 
the underlying mechanisms can be changed to accomodate devices like smart 
cards. 



Interoperability with X.509 (Informational) 

X.509 certificate infrastructures [see RFC245ff[ are becoming more and more 
common. An X.509 certificate binds an entity's distinguished name to its public key. 
This is very similar to the way in which a SPKI name certificate binds a name to a 
public key. One difficulty is that in SPKI the Issuer is denoted by a public key. In 
X.509 the Certificate Authority is denoted by a "distinguished name". Its public key 
is not required to be in the certificate. When it isn't there, the Certificate Authority 
is assumed to have a well-known public key. 
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An e-speak CI can take an X.509 certificate, verify it (check it is signed by a trusted 
Certificate Authority) and issue an e-speak Name Certificate binding an encoding of 
the subject's X.509 distinguished name to the subject's public key. (This is not 
supported in the current release.) 

In addition the e-speak certificate verifier could be extended to handle X.509 name 
certificates natively, automatically converting them to SPKI name certificates as 
outlined above. (This is not supported in the current release.) 

X.509 version 3 also supports attribute certificates and work is on going within the 
IETF on defining a profile for attributes to use within the Internet's PKIX 
infrastructure. It is not possible to define a useable mapping from X.509 attribute 
certificates into SPKI authorization certificates, as X.509 attributes can be arbitrary. 
In principle it should be possible to define a mapping from SPKI certificates into 
X.509 attribute certificates. 



SPKI BNF Formats 

E-speak uses two BNF syntaxes. The "advanced" syntax is used for manually-input 
data and human reading. It has been used throughout this document. Its advantages 
for this purpose are allowing white spaces (including line-feed) , and base64 and hex 
codings of numbers. The base64 coding allows public keys to be written with 
relative brevity. 

The parser accepts certificates in advanced syntax or canonical syntax, and outputs 
them in canonical syntax. This is used for all internal operations, such as protocol 
exchanges, and for serialized transmission. All hashes are computed on data in 
canonical syntax. This is necessary, because varying numbers of white spaces 
would produce invalid hashes. 

Advanced Syntax 

The advanced syntax follows. Its initial non-terminal is <s-part>. 

<alpha> = [a-zA-Z] ; 

<base64> = "##" {<base64-char> | <space>) * "#" ; 
<base64-char> = <alpha> | <digit> | [+/=] ; 
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<bytes> ^ <token> | <string> | <raw-bytes> | <quoted-string> I 
<base64> | <hex> ; 

<byte-string> = <display- type>? <bytes> <decimal> = [0-9]+ ; 
<digit> = [0-9] ; 

<display-type> = " [" <bytes> "] " ; 

<liex> = "#|" (<hex-digit> | <space>)* "|"; 

<hex-digit> = [0-9A-Fa-f ] ; 

<punctuation> = [\-./_:*+^] | ['^,@] | [$%'^&\ [\] #-<>?: | ] ; 
<guoted-string> = "#<" {delimiter char c} {delimiter string s 
not containing c} {c} 

{any cliaracter strng not containing s} {s} ; 
<raw-bytes> = <decimal> {binary byte string of that 

length} ; 

<s-expr> = "(" (<s-part> | <space>) * ; 
<space> ^ [ \t\r\n]*; 

<s-part> = <byte-string> ( <s-expr> ; 
<string> = "\"" {string chars} "\"'. . 
<token> = (<alpha> | <punctuation>) 
{<alpha> I <punctuation> | <digit> )* ; 

We also allow end-of-line comments indicated by 1 . Comments are treated as white 
space. 

Within a string C conventions may be used, including octal escape sequences. 
Specifically: 

\b bacJcspace (010) 
\f formfeed (014) 
\n newline (016) 
\r return (015) 
\t tab (Oil) 
\nnn octal escape 

Where nnn is a 3-digit octal numeric in the range Og - 177g , which is Ojo - 127io 
Canonical Syntax 

The canonical syntax defines the following. 

<bytes> = <raw-bytes> ; 
<decimal> = [1-9] [0-9]* | "0" ; 
<s-expr> = "(" <s-part>* ")" ; 

This disallows space in lists, all byte forms except counted string, and insists that 
decimal numbers have no redundant leading zeros. Hashes are always computed 
over canonical forms. 



110 



Developer Release X.03.03.00, September 2000 



Access Control 



SPKI BNF Formats 



Within certificates, lists must start with a byte string and be non-empty: 

<s-expr> = "(" <bytes> <s-part>* ")" ; 

The following is the BNF currently recognized. The top-level non-terminals are: 

_ <cert>: a certificate. 

_ <name-cert> : a name certificate 

_ <proof> : a certificate justification. 

<proof> is used in the messaging protocol. (See ] 

In the messaging protocol (See Chapter 6, Xommunication") we use tag lists for 
queries and requirements. 

<cert> =^ "cert" <version>? <cert-display>? 

<issuer> <issuer-inf o>? 

<subject> <subject-info>? 

<deleg>? <tag> <valid>? <comment>? ; 
<cert-display> = "display" <byte-string> ; 

<comment> = "(" "comment" <byte-string> ; 
<date> = <byte-string> ; 
<date-expr> = <byte-string> ; 
<deleg> = "propagate" ")" ; 

<full-name> = "(" "name" <principal> <byte-string>+ ")" ; 
<gte> = "g" ( "ge" ; 

<hash> = "(" "hash" <hash-alg-name> <hash-value><uris>? ")" ; 

<hash-alg-name> = "mdS" | "shal" | <uri> ; 

<hash-of -key> = <hash> ; 

<hash-value> <byte-string> ; 

<issuer> = "(" "issuer" <principal> ")" ; 

<issuer-info> = "(" "issuer- info" <uris> ")" ; 

<issuer-name> - "(" "issuer" " (" "name" <principal> <byte- 

string> " ) " " ) " ; 

<low-lim> = <gte> <byte-string> ; 
<lte> = "1" I "le" / 

<name> = < relative- name > | <full-name> ; 
<name-cert> = "(" "cert" <version>? <cert-display>? 

<issuer-name> <issuer-info>? 

<subject> <subject-info>? 

<valid> <comment>? ")" ; 
<not-after> = "{" "not-after" <date> ") " ; 
<not-before> = "(" "not-before" <date> ")" ; 
<n-val> = <byte-string> ; 

<object-hash> = "(" "object-hash" <hash> ")« ; 
<one-valid> = "(" "one-time" <byte-string> ") " ; 
<online-test> = "{" "online" <online-type> <uris>? <principal> 
<s-part>* ")" ; 
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<online-type> = "crl" | "reval" | "one-time" ; 
<principal> = <public-key> | <hash-of -key> ; 
<proof> =^ (<cert> | <name-cert>) * 

<piiblic-key> = "(" "public-key" <pub-sig-alg-id> <s-expr>* 
<uris>? ") " ; 

<pub-sig-alg-id>= "rsa-pkcsl-tndS " | "rsa-pkcsl-shal " | "rsa- 
pkcsl" I "dsa-shal" | <uri> ; 

<range-ordering>= "alpha" | "numeric" | "time" | "binary" I 
"date" ; 

<relative-name> = "(" "name" <byte-string>+ ")" ; 
<requires> = "(" "requires" <tag>* ")" ; 
<restrict-date> = "(" "date" <date-expr> ")" ; 
<restriction> = <restrict-date> | <target> | <requires> ; 
<restrictions> = <restriction>* ; 

<reval> = "(" "reval" <version>? <subj-hash> <reval-body> ") " ; 
<reval-body> = <one-valid> | <valid-basic> ; 

<signature> = "(" "signature" <hash> <principal> <sig-val> ")" ; 
<sig-val> = <s-part> ; 

<subject> = "(" "subject" <subj-obj> ") " ; 
<subject-info> = "(" "subject- info" <uris> ")" ; 
<subj-hash> = " (" "cert" <hash> ")" ; 
<subj-obj> = <principal> | <name> | <object-hash> ; 
<tag> = "C" "tag" <tag-expr>* ")" ; 
<tag-and> = "(" "*" "and" <tag-expr>+ ")" ; 
<tag-expr> = <byte-string> | <tag-simple> 

<tag-prefix> | <tag-range> 

<tag-set> | <tag-and> 

<tag-star> ; 

<tag-simple> - "(" <byte-string> <tag-expr>* ")" ; 
<tag-prefix> = "(" "*" "prefix" <byte-string> ")" ; 
<tag-range> = "(" "range" < range- ordering > 

<low-lim>? <up-lim>? ")" ; 

<tag-set> = "(" "*" "set" <tag-expr>* ")" ; 

<tag-star> = "{" "*" ")" ; 

<target> = "(" "target" <tag-expr>* ")" ; 

<up-lim> = <lte> <byte-string> ; 

<uri> - <byte-string> ; 

<uris> = "(" "uri" <uri>* ")" ; 

<valid> = <valid-basic> <online-test>* <restrictions> ; 
<valid-basic> = <not-before>? <not-after>? ; 
<version> = "(" "version" <byte-string> ")" ; 

The elements <reval>, <online-test> (and related elements such as crl) and 
<restrictions> are parsed but silently ignored in the current implementation. 
Architectural extensions will be introduced to support these elements. 
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Overview 

The only way for a Client to request access to a Resource from a Resource Handler 
is to send a message through the e-speak core. The only way for a Resource Handler 
to return a reply to a Client is to send a message through the e-speak core. Thus, the 
core mediates all access between Clients and Resource Handlers, It is the only 
entity to accept connections: Clients and Resource Handlers establish connections 
to an e-speak Core so that they can communicate with each other. 

AH messages handled by e-speak cores are Protocol Data Units (PDU's) , described 
below. 

The possible exchanges of messages follow the Session Layer Security protocol 
''Session Layer Security Protocol (SLS)" on page 132. 

Mediation by the e-speak core may include: 

• Determining to which Inbox to route the message. 

• Determining how to route the message (its routing path) . 

• Processing and transforming the message headers and contents. Only 
limited processing of the message is possible if security is enabled, 
implying that a Message Authentication Code (MAC) is appended. If so, 
fields of the PDU header which have been used to form the MAC must not 
be changed "Authentication of messages" on page 144. 

Mediation is transparent to the Client and Resource Handler. 
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The e-speak core keeps no state information about messages beyond the time 
needed to complete processing. It does not keep any information about replies to 
messages. As far as the core is concerned, a reply is another message. It doesn't 
distinguish between clients and resource handlers: an entity which sends it a 
message is a "client" so far as it is concerned, and the destination is simply an Inbox. 

If a Client needs a reply, it may wait or send another message; all messaging is 
asynchronous. Each asynchronous message has an identifier set by the sender. A 
reply can refer to this identifier so the Client knows to which message the reply has 
been sent. 

Figure 6 shows the flow of messages through an e-speak core when a Client sends 
and receives messages from a Resource Handler. 
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Figure 6 Message flow with an e-speak core 
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A client is not restricted to resources connected to the same e-speak core as itself. 
Figure 7 shows the message flow when a Client sends and receives messages from 
a Resource Handler on a remote e-speak core. The same protocol is used to 
exchange messages between e-speak cores as is used to exchange messages 
between Clients and e-speak Cores. 




OB = Outbox 
IB = Inbox 

Figure 7 Core-to-core message flow 

The creation and management of core-to-core communications is decribed below 
(see "Core to core communication" on page 151). 
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All messages exchanged between e-speak cores, and between e-speak cores and 
clients are PDUs. A single PDU corresponds to a single Session Layer Security (SLS) 
Message. 

A class hierarchy for PDU's is shown in Figure 8. The members PDU.data, 
HandShake.data and MessageForResource.payload are all byte-arrays which in 
principle could hold an object of any class. Which class-instances are present in a 
PDU is given by the values of: 

• PDU.messageType - for the contents of PDU.data 

• HandShake.type - for the contents of HandShake.data, if present. 

• MessageForResource.payloadType - for the contents of 
MessageForResource.payload, tf present 

The permissible values of PDU.messageType and the corresponding contents of 
PDU.data are: 



ALERT (0) 
HANDSHAKE (1) 
APPLICATION_MESSAGE (2) 
TUNNEL (3) 
PING (4) 



Alert 



MessageForResource 
(Tunneling) PDU 
Ping 



Handshake 
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Figure 8 PDU class hierarchy 
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The class PDU is: 

class PDU { 

int versionMajor; 

int versionMinor; 

int spi; 

int spi Sender; 

int serial ; 

int inReplyTo; 

int messageType; 

int encodingType; 

String toAddress; 

String f romAddress ; 

byte[] route; 

byte [3 data; 

} 

Version no.s 

The current value for versionMajor is 1, and for versionMinor is 0. 
SPI members 

SPI stands for Session Parameter Index. This is used by the two endpoints in the 
Session Layer Security protocol to indicate which session the message is being sent 
on. Since the sender and the receiver may identify the SPI separately we have two 
fields: spi denotes the recipient s SPI; spiSender denotes the sender s SPI. 

Message serial no. fields 

Two fields are used by SLS to protect against replay attacks: serial is set by the 
sender; inReply to is the serial field of the message to which the sender is 
responding. 

Message types 

The following values for message type are defined: alert (0), handshake (1), 
application message(2), tunnel(3), ping(4). Alert, handshake, tunnel and ping are 
used in SLS to manage sessions "Session Layer Security Protocol (SLS)" on 
page 132. These types are described in the following section. 
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Encoding types 

The following encoding types are defined for a PDU: clear data ( 0) ; protected 
data(l); secure data (2). Protected data is authenticated and protected from 
tampering by a Message Authentication Code (MAC) [see Schneierpp, 455-459^. 
Secure data is protected by a MAC and also encrypted for confidentiality. 

Addresses 

The String toAddress is an absolute ESName [see ESNames section below] and 
denotes the destination for the message. The String fromAddress is also an absolute 
ESName. It denotes the sender of the message and can be used for replies. The e- 
speak core attempts to resolve these names in its Root name-frame by finding the 
Mapping Object (see Chapter 4, "Core-Managed Resources**) associated with each 
ESName. The Mapping Object is used by the e-speak core to refer to a Resource, a 
Search Recipe, or any combination. 

If the e-speak core cannot unambiguously identify the Resource Handler for the 
toAddress, it will send an exception message to the Client The format for an 
exception message is described in Chapter 7, Exceptions", The possible 
exceptions are shown in Table 7 on page 131. 

Route member 

The byte-array route can be used by applications to pass routing data. This is never 
encrypted or protected by a MAC. 

Data member 

The format of this byte-array is determined by the encoding type. If the encoding is 
clear data, the byte array is a message body, of contents indicated by the message 
type. 

If the encoding is secure data, then it has been encrypted according to the cipher 
negotiated in the SLS session set-up. Once it has been decrypted, it will have the 
same format as protected data: a MAC, followed by the message body. The contents 
of the message body is indicated by the message type. It will be an object of one of 
the classes described below. 

These elements of a PDU are marshalled in the order of member definition shown 
in the class declaration above. 
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Marshalling of PDU Elements 

In general. PDU s are marshalled according to the PDU marshalling format (PDFM) 
described below (see "PDU Marshalling format" on page 170). This applies to the 
PDU class listed above. However, for application messages the e-speak serialization 
format (ESF) (see "E-speak Serialization Format" on page 170) is used in principle. 
Currently this is not compatible with SPKI certificate formats (see Chapter 5, 
Access Contror), so some messages are serialized partly using PDFM and partly 
using ESF. Where this happens we label each field either (PDFM) or (ESF). 
Otherwise we label the class corresponding to the message type. 

Top Level PDU Message types 

The data member of a PDU will contain an instance of one of the following classes, 
depending on PDU.messageType, as explained above. The elements of each 
message are marshalled in the order in which they appear in the class definition. 

Alert 

Class Alert { (PDFM) 
byte level; 
byte code; 
String detail; 

} 

The Alert message is used for SLS session management. Valid level values are: 

fatal(OxOO) 
warning (0x01) 
debug (0x02) . 

All codes are normally sent with a level of fatal, unless indicated. Valid codes are: 

• CLOSE_NOTIFY (0x00) (warning) 

• UNEXPECTED_MESSAGE (0x01) 

• BAD_SPI (OxOA) 

• BAD.SERIAL (OxOB) 

• BAD_MAC (OxOC) 



Developer Release X.03.03.00, September 2000 



Communication 



Protocol Data Unit (PDU) 



• HANDSHAKE_FAILURE (0x14) 

• BAD_CERTIFICATE (0x15) 

• UNSUPPORTED_CERTIFICATE (0x16) 

• CERTIFICATE_REVOKED (0x17) 

• CERTIFICATE_VERIFICATION_FAILED (0x18) 

• ILLEGAL_PARAMETER(0xlE)=30; 

• BAD_PROTOCOL_VERSION (OxlF) 

• INSUFFICIENT.SECURITY (0x20) ; 

• NO_RENEGOTIATION(0x28) (warning) 

• ERROR (0x32) 

The detail String is intended for human consumption and is left unspecified. 

Default and Implicit Session Alerts 

These are newly introduced, to handle the following situations: 

• A request is made on the default Session (SPI = 0, no security) , but the recipient 
requires a secure Session, The recipient sends back an alert with the code 
INSUFFICIENT_SECURITY, and the requestor can establish a secure Session in 
response. 

• A request is made on a secure Session, to a Resource that previously 
communicated on that Session, but that Session has died (due to disconnection 
or other causes) at the recipient's end. The recipient sends an alert with the code 
BAD_SPI. The requestor removes that Session (which it previously had stored 
under the URL of the Resource) and may negotiate a new Session, 

Handshake 

class Handshake { (Pi^FAT) 
int type; 
byte data [] ; 

} 
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The possible values of Handshake.type and the corresponding contents of 
HandShake.data are described below (see "Handshake message types" on page 125) 

Application message 

When APPLICATION.MESSAGE is the message type, the data field of the PDU 
contains an instance of MessageForResource. 

class MessageForResource { (PDFM) 
byte versionMajor; 
byte versionMinor; 
ADRList tags; 

short secondaryABIVersion; 
byte payloadType; 
boolean isVoid; 

byte payload[] ; (ESF this field only) 

The current value of versionMajor is 2 and of versionMinor is 0. These are 
different from the members with the same names in the PDU class. 

ADRList is a list of SPKI tags using the *-set form as defined in " SPKI BNF Formats" 
(Chapter 5, "Access ControF ) 

secondaryABIVersion currently has the value 0, It specifies the format of the data 
field when communicating with core-managed resources, 

isVoid indicates whether or not there is a payload. If isVoid is true, there is no 
payload and it is not marshalled or unmarshalled, 

payloadType and the corresponding class-instances held in payload are described 
below (see "Payload Message Types" on page 128). 

Tunnel 

If the message type of PDU isTUNNEL, the data field of the PDU contains another 
PDU. The outer PDU is removed. The PDU contained in the data field is 
unmarshalled and forwarded to the address contained in the toAddress field of the 
inner PDU. The contents of the inner PDU, except for the toAddress field, may be 
encrypted - the object is to pass encrypted messages across a firewall. 
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Ping 

class ping{ (PDFM) 
String ID; 
byte type; 
} 

Ping messages are used by SLS for session management. 
The current value of ID is "SLS:Ping:vLO". 
Two values of type are defined: 

• Request (0x00) 

• Reply (0x01) 

Handshake message types 

The value of HandShake.type indicates the contents of HandShake.data, as follows: 
TYPE VALUE CLASS-INSTANCE IN DATA 

HANDSHAKE^REQUEST (0) HandShakeRequest 
HANDSHAKE_START (1) HandShakeStart 
HANDSHAKE.REPLY (2) HandShakeReply 
HANDSHAKE.FINISH (3) HandShakeFinish 
In all the classes, listed below: 

• The current value of the ID member is "SLS:HandshakeStart:vl .0". 

• The current values of majorVersion and minorVersion, if present, are 
0x01 and 0x00 respectively. They indicate the highest version of SLS 
supported by the sender. 

Handshake request 

class HandShakeRequest { (PDFM) 

String ID; 

boolean flag; 

PDU pdu; 

} 
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Handshake request is used to request a renegotiation of the session parameters. 

The boolean flag is set to true if the request includes a PDU, otherwise no PDU is 
included. The PDU is intended to be used for synchronization: it would contain the 
last message between the two parties. Currently it is not used. 

Handshake start 

class HandShakeStart { (PDFM) 

String ID; 

byte majorVersion; 

byte minorVersion; 

int spi; 

ADR group; 

ADR keyData; 

ADR cipherSuiteList ; 

ADR tags; 

ADR query; 

} 

The type ADR (ASCII Data Representation) is an s-expression as defined in Chapter 
5, *^ Access Contror - "SPKI BNF Formats" . All the Handshake classes have ADR 
members. 

spi is the session parameter index of the sender of this message. 

group is the definition of the Diffie-Hellman group. 

keyData is the sender's part of the Diffie-Hellman key-exchange. 

CipherSuiteList is the list of valid cipher suites in decreasing order of preference. 

tags is the list of SPKI tags the sender is requiring the receiver to prove. 

query is the sender s query on the recipient. The sender can use this field to declare 
the operations it wishes to invoke within the session once it is established. This can 
be used by the recipient to determine what tags it will require the sender to prove. 

Handshake Reply 

class HandshakeReply{ (PDFM) 

String id; 

byte majorversion; 

byte minorversion; 

int spi; 

adr keydata; 
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adr ciphersuite; 

adr proof; 

adr tags; 

boolean relay; 

String f orwardaddress; 

adr signature; 

} 

spi is the Session Parameter Index of the sender, 

keydata is the sender ^s part of the DifTie-Hellman key exchange. 

ciphersuite is the sender s chosen cipher suite selected from the list of cipher 
suites in the initial HandshakeStart message. 

proof is the list of certificates that will prove the tags that the sender of the 
HandshakeStart message required. 

tags is the list of tags the sender is requiring the receiver to prove. This may have 
been generated by having examined the query member in the intial HandshakeStart 
message. 

relay is set to true if the responder will relay subsequent messages to the addressee: 
a tunnel is to be set up. If relay is true, the responder will not have to produce 
certificates authorizing the tags requested in the HandshakeStart message. 

If relay is set to true, forwardAddress will contain the absolute ESName of the 
recipient to which this message is to be forwarded, 

signature is the signature of the hash of this message and the initial 
HandshakeStart message. 

Handshake finish 

class HandshakeFinish{ (PDFM) 

String id; 

adr proof; 

adr signature; 

} 

proof is the list of certificates that will prove the tags that the HandshakeReply 
message requires (in that message's tags member). 

signature is the signature of the hash of this message, the previous 
HandshakeReply and the HandshakeRequest message. 
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Payload Message Types 



The value of MessageForResource.payloadType indicates the contents of payload 
as follows: 



The payload field contains the message for the resource. 

The payload format is not specified if the payload type is set to OBJECT. This is for 
use by applications to communicate with external resources. The Resource Handler 
can specify any format it chooses. 

Payload of messages to Core-Managed Resources 

A PDU sent to a core-managed resource has the payload type METHOD_CALL, and 
the payload member contains a methodCall object: 

public class methodCall (ESF) 



The first two fields define the interface and method to be invoked. The type "Ob" 
stands for any object that can be marshalled in ESF. 

Initial Connection Request 

A client's initial request for connection is an example of a PDU with a payload as 
above.. The fields are set as follows: 

interf aceName = '*core" 
methodName - "bootstrap" 
arguments = null 



PAYLQ ADTYPE VALUE 



CLASS-INSTANCE IN PAYT OAn 



METH0D_CALL (0) 
METH0D_RESULT (1) 
EXCEPTION (2) 
EVENT (3) 
OBJECT (4) 



methodCall 

methodResult 

exceptionResponse 



eventMessage 
(unspecified) 



String interf aceName ; 
String methodName 
Ob[] arguments; 
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Routing to External Resources 

A message to an external resource is also sent as a PDU to the e-speak core, but with 
the payloadType OBJECT and a payload unspecified by e-speak. The e-speak core 
will route this message to the resource handler if it can. 

It cannot do so if the " To" field of the message is not a valid Resource, or if the Inbox 
specified in the destination Resource metadata is not connected to a Resource 
Handler, or if the Resource Handler^s Inbox is full. 

When it cannot deliver the message, the e-speak core will return an error 
(exception) message to the Client, if it can. If the Client's Inbox can^t take the error 
message for any reason, the e-speak core discards the message. 

Normally, the e-speak core places the following data in the route field of the PDU: 

class routeData{ 
String slot; (PDFM) 

boolean specif icationNonNull ; (PDFM) 

ESmap privateRSD; (ESF) 

ADR mask; (PDFM) 

ADR servicelD; (PDFM) 

} 

The slot field is used to enable many Inboxes to share a single channel (TCP 
connection in the current implementation). The slot identifies which Inbox the 
message is for. 

If specificationNonNuU is set to false, the three fields following are not marshalled. 
These three fields are parts of the resource s metadata held by the e-speak core. 
The privateRSD field is the resource s private RSD, 

The mask field tells the resource handler which methods have security disabled. 

The servicelD field is the service identity for the resource. Both these fields are 
<tag-expr> as defined in Chapter 5, "Access Control" - "SPKI BNF Formats". 
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Payload of messages from Core-Managed Resources 
Initial Connection to the Core 

The e-speak Core listens on a TCP port for Client connections (the default port is 
12345). When it receives a connection request (see "Initial Connection Request" on 
page 128) a TCP channel is created between the Client and the Core. The Core 
creates a default protection domain for the Client and sends a PDU back to the 
Client, of type MessageForResource, with payloadType set to METHOD_RESULT. 
The methodResult in the payload will contain a bootstrapReply object: 

class bootstrapReply{ (ESF) 

ESname Inbox; 

String InboxSlot; 

ESname CallbackResource; 

ESname ExceptionHandlerResource ; 

String anchor; 

} 

Inbox and InboxSlot are the ESnames of the inbox and the slot allocated by the 
e-speak core to the client. The CallbackResource field is the ESname to be used 
to send messages to the client. This should be used in the fromAddress field of 
PDU^s sent by the client. 

The ExceptionHandlerResource is deprecated and should not be used. 

The anchor field is the URL of the root name-frame of the Protection Domain 
which has been created by the e-speak core for the client. 

Normal reply 

A PDU sent from a Core-managed Resource, in reply to a methodCall when no 
exception has been thrown, has the payload type METHOD_RESULT, and the 
payload member contains a methodResult object: 

public class methodResult 
{ 

Ob result; (ESF) 
} 

The bootstrapReply sent in reponse to a connection request is a special case of 
methodResult. 
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Exceptions 

When an exception is thrown the payloadType is EXCEPTION and the payload 
member of messageFor|Resource is an instance of exceptionResponse: 

public class exceptionResponse { 

Ob result; (ESF) 

} 

One of the following exceptions will be thrown when the e-speak core cannot 
unambiguously identify the Resource Handler for a given toaddress: 



Table 7 Exceptions for unresolved Resource Handler 



Exception 


Description 


NameNotFound Exception 


The lookup procedure failed to find a 
Mapping Object 


UnresolvedBindingException 


The only accessors in the Mapping Object 
are Search Recipes. 


MultipleResolvedBindingException 


The explicit bindings in the accessors refer 
to Resources with different Resource 
Handlers. 


UndeliverableRequestException 


The Resource Handler does not have the 
Resources needed to receive this message, 
or the Handler Inbox is not currently 
connected. 



Events 

When the core generates an event it will send a PDU with the data field containing 
a messageForResource, which will have the payloadType set to EVENT. The 
payload will be an eventMessage. 

public class eventMessage 



Ob result; (ESF) 
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Messages from a Resource Handler to a Client 

E-Speak implements a peer-to-peer communications model for messaging. 

The Core does not distinguish between a message sent from a Client to a Resource 
Handler and a reply from the Resource Handler back to the Client The Resource 
Handler sending a reply to a Callback Resource is treated as the Client, and the 
Client receiving the reply is treated as the Resource Handler for die Callback 
Resource. 

Clients may have more than one Inbox. The only way for a Client to receive a 
message from any other Client is to register a Resource listing one of its Inboxes in 
the Resource Handler field of the metadata. Clients can manage different classes of 
messages by registering different Resources designating different Inboxes. Clients 
can also deal with different message classes by associating certain classes with 
Events. 



Session Layer Security Protocol (SLS) 

The Session Layer Security (SLS) Protocol determines all possible exchanges of 
PDU messages between clients, e-speak cores and resource handlers. The protocol, 
used between a client and a resource handler, may establish a secure session 
between them. It can also be used to establish an open, non-secure session. All SLS 
communication is carried in PDU messages, and all PDU messages are sent under 
the SLS protocol. 

A secure session has the following properties. 

• All messages exchanged between die two end points are authenticated. This 
prevents messages being changed or messages being inserted into the TCP 
connection by a third party (e.g. an attacker). 

• All message exchanged between the two end points are protected against replay. 
This prevents a third party capturing the messaging and replaying it at a later 
date to trigger a repeat of the action taken by the recipient. 
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Messages exchanged in a secure session may be encrypted for confidentiality. This 
prevents a third party from reading the contents of a message. 

In a non-secure session messages are exchanged without encryption, 
authentication or protection against replay. 

The SLS (Session Layer Security) protocol extends the capabilities of SSL [see RFC 
2246i,a protocol that is supported by most modem web browsers, and is currently 
the default way to secure client/server interactions over the web. The motives for 
departing from SSL are: 

• Transport independence: SSL links a security session with a TCP socket. If the 
socket dies the security session dies with it: something undesirable when the life 
expectation of a security session is very different from the life expectation of the 
transport. Also, we cannot multiplex several security sessions onto the same 
socket, or perform dynamic load balancing of the end-point without starting the 
session from scratch. Moreover, even though properties like reliability and in- 
order delivery of messages are critical for a security protocol, some TCP details 
are not, and this might put unnecessary restrictions on the applicability of SSL. 
Finally, in some cases we might want to use a different transport for sending and 
receiving messages (i.e., outgoing messages use a different firewall needing two 
sockets). SLS tries to make the minimum number of assumptions on the 
communication transport solving most of the issues above. 

• Tunnelling support: During firewall traversal we might want the firewall to 
control the client access rights to the internal LAN for every packet. However, 
we might not want die firewall to see all the traffic in clear (therefore, losing the 
end-to-end security property). This is difficult to achieve with SSL because 
either we let the client open a direct socket to the service or the firewall will see 
all the traffic in clear. On the other hand, with SLS we can nest a secure session 
inside another one, possibly with different end points, allowing to achieve both 
goals simultaneously. 

• Elliptic cryptography: Most implementations of SSL only support Diffie-Hellman 
key agreement algorithms based on exponentiation. SLS uses a faster algorithm 
based on Elliptic Curve Cryptography (ECC) described by [Seroussiand 
Swarti, 
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• Attribute certificates using SPKI [see RFC 2692 - 2693{ . SSL only supports X509 
name certificates, mainly to authenticate that the end-point "owns", according 
to a configured " trusted C A" , the web address that we wanted to reach. Only one 
certificate by each party can be used, and in most cases only server 
authentication is performed. On the other hand, SLS performs a negotiation of 
tags that need to be proven represented by multiple SPKI certificates. This 
allows a fine grained control of security by mapping tags to actual permissions, 
raising the level of abstraction from "a stream of bytes" in SSL to a particular 
operation on service X in SLS, making it easier to integrate with application level 
security. Details on the use of SPKI certificates in SLS can be found in Chapter 
5, "Access ControF. 

• Latency minimization: SLS allows the client to send application data after a 
round-trip negotiation has succeeded. In SSL two round-trips are needed before 
the application data is sent. This can have important performance implications 
when network delays are large and we need a quick response from the server. 

Functional Description of SLS 

In this section we describe the expected behavior of the protocol. 
Protocol message types 

Every SLS message is embedded in a PDU (Protocol Data Unit) (see "Protocol Data 
Unit (PDU)" on page 118), which contains header information allowing the system 
to dispatch it to the correct security context, route it through the network, identify 
replies, ensure the protocol version and so on.Two fields of this header relevant to 
our discussion classify messages according to the type of encoding and their 
purpose: 

Supported encoding types 

• CLEAR_DATA: The message is not encrypted or protected against modification. 

• PROTECTED_DATA: The message is not encrypted but it is protected against 
modification with a signed digest (MAC) 

• SECURE_DATA: The message is encrypted and protected against modification 
using a MAC. 
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Supported message types 

• HANDSHAKE: Message exchanged during the key-agreement protocol. There 
are four types of handshake messages that will be discussed later. 

• ALERT: Message that identifies an abnormal situation during the handshake or 
after the session has been established. ALERT messages can be fatal, forcing 
session termination, or just warnings, for which the response is implementation 
dependent. 

• APPLICATION.MESSAGE: Message that communicates application data. 

• TUNNEL: A message that contains another PDU in its payload. This is used to 
nest sessions, something important for firewall traversal. 

• PING: A heartbeat message that is used by the session scavenger to know if the 
session is still active. 

• REKEY: Forces a key offset of the instantiated cipher suite based on the 
previously negotiated shared secret. (REKEY is not supported in the current 
implementation.) 

High level protocol state machine 

Figure 9 High level state transitions in SLS. 




Figure 9 shows the possible states of a session, and what triggers transitions 
between them. There are four possible states: 

• START: the session object has been created but it is not fully configured. Also, 
the key agreement protocol has not started. 
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• SET_UP: the key agreement protocol has started. We do not have a shared secret 
yet, so all the messages have CLEAR.DATA encoding. It depends on the 
implementation whether any response is made to unauthenticated ALERT 
messages. 

• READY: the key agreement protocol has successfully completed. We have a 
working session that we can use to encrypt/decrypt messages and validate 
whether the session has certain security tags associated with it. At this point 
ALERT messages are authenticated and should not be ignored. 

• DEAD: the session is no longer operational and will never be. We can safely 
scavenge it. 

Also, we can see in Figure 9 the events that trigger state transitions: 

• init: complete the initialization of the session object and send a message to the 
other party (if needed) to start the key agreement. 

• sessionOK: The key agreement has finished successfully and we have a new 
cipher suite to install in the session. 

• timeout; a timeout expired. The different timeouts are explained in detail below 
(see "Timeouts description" on page 146). 

• alert: an authenticated (or optionally non-authenticated) fatal alert was handled/ 
sent forcing a shutdown of the session. 

• close: a client forced termination of a session by invoking the close 0 method. 
Two important operations on a session are handling and sending a PDU. 

SLS Handling a PDU 

The handling operation assumes that the PDU has already been received from the 
transport and invokes some security processing on the PDU (i.e., decryption/ 
authentication). 

Depending on the state of the session, and the encoding/type of the PDU, the 
session behaves differently while handling PDUs. Table 8 on page 138 shows the 
expected behavior of a session when handling a PDU. 

The terms in that table have these meanings: 
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• MAC: either PROTECTED^DATA or SECURE_DATA encoding type. Obviously, 
the important property is that the PDU is correctly authenticated, otherwise we 
will always ignore the message regardless of its claims. 

• Exception: notify the client doing the handling that the session is not 
operational. 

• Ignore: do not take any significant action based on that PDU (i.e., change session 
internal state). Optionally, an implementation could log the event that a PDU is 
being ignored. 

• Optional: an action is considered optional if an implementation can decide to 
ignore the PDU instead. 

• Warning: send a warning ALERT response to the other party. 

• HandleHsh: handle a HANDSHAKE PDU by making progress in the key 
agreement protocol This could involve an Internal Send of a HANDSHAKE or 
ALERT PDU to the other party. 

• HandleAl: handle an ALERT PDU, This might involve closing the session if it is 
a fatal alert, or logging the event otherwise 

• HandleApp: handle an APPLICATION_MESSAGE PDU. Typically, the PDU will 
be passed in clear text to the client if it authenticates and/or decrypts correctly; 
otherwise it is ignored. 

• HandleTun: handle a TUNNEL PDU. This could involve "peeling off the outer 
PDU, returning the inner one (after decryption/authentication of the outer one) 
or calling a custom handler to deal with it. 

• HandlePin: handle a PING PDU. This handling might require sending a reply 
PING PDU or just record that our previous PING has been replied successfully. 

• HandleRe: handle a REKEY PDU. Forces the re-key of the handler part of the 
crypto suite. 
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Table 8 PDU handling behaviour depending on state 



TYPE 


ENCODE 


START 


SET.UP 


READY 


DEAD 


HAND- 
SHAKE 


CLEAR 


Exception 


HandleHsk 


Ignore 


Exception 


MAC 


Exception 


Ignore 


Warning 


Exception 


ALERT 


CLEAR 


Exception 


HandleAl 
Optional 


Ignore 


Exception 


MAC 


Exception 


Ignore 


HandleAl 


Exception 


APPLICA- 
TION 


CLEAR 


Exception 


Ignore 


Ignore 


Exception 


MAC 


Exception 


Ignore 


HandleApp 


Exception 


TUNNEL 


CLEAR 


Exception 


Ignore 


Ignore 


Exception 


MAC 


Exception 


Ignore 


HandleTun 


Exception 


PING 


CLEAR 


Exception 


Ignore 


Ignore 


Exception 


MAC 


Exception 


Ignore 


HandlePin 


Exception 


REKEY 


CLEAR 


Exception 


Ignore 


Ignore 


Exception 


MAC 


Exception 


Ignore 


HandleRe 


Exception 



SLS Sending a PDU 

The sending operation will first invoke the required security processing (i.e, 
encoding, MAC computation) and then it will use the underlying transport to deliver 
the message at the other end. Note that handling a PDU might have as a side effect 
that another PDU is sent to the other party, i.e., a response to a handshake message 
during the key agreement. We call that case an internal send as opposed to an 
external send directly invoked by the client 
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Table 9 shows the expected behavior when trying to send a PDU through a session. 
Table 9 PDU sending behavior depending on state 



TYPE 


MODE 


START 


CFT TIP 






TJ A XTr\ 

xlAND- 
SHAKE 


Internal 


NotApply 


OK 


OK 


NotApply 


External 


Exception 


Retry 


OK 


Exception 


ALERT 


Tnt'f*T*n Q 1 
llltCillai 


iNO[/\ppiy 


UJv 


UK 


NotApply 


External 


Exception 


Retry 


OK 


Exception 


APPLICA- 
TION 


Internal 


NotApply 


NotApply 


NotApply 


NotApply 


External 


Exception 


Retry 


OK 


Exception 


TUNNEL 


Internal 


NotApply 


NotApply 


NotApply 


NotApply 


External 


Exception 


Retry 


OK 


Exception 


PING 


Internal 


NotApply 


NotApply 


OK 


NotApply 


External 


Exception 


Retry 


OK 


Exception 


REKEY 


Internal 


NotApply 


NotApply 


OK 


NotApply 


External 


Exception 


Retry 


OK 


Exception 



Some terms in that table deserve further explanation: 

• NotApply: it is an implementation error if the protocol tries to send this message. 
This is only relevant for internal messages: the implementation does not have 
control over possible external messages. 

• OK: this means that the session will perform the appropriate processing and try 
to deliver it to the lower layer. This does not mean that the message has been 
correctly sent, because this depends on the status of the underlying transport/ 
session. 
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• Retry: The client is informed that the session is currently unavailable to send 
messages but this might change in the future. 

• Exception: The client is informed that the session is permanently unavailable. 

The key-exchange protocol 

The key-exchange protocol is an authenticated Diffie-Hellman key exchange. From 
the session key agreed in the DifTie-HeUman exchange further keys are derived for 
encryption and confidentiality. 

Features of the exchange are: 

• Elliptic Diffie-Hellman key exchange instead of modulus exponentiation. 
Instead of choosing a group and checking its validity at the other end, we pick 
one of a pre-determined family of elliptic curves [see Seroussi & Swar^. Each 
party uses a random point on the curve as a private key. generates a second point 
from the first to send as a public key, and checks that the point he receives 
belongs to the same curve. 

• There is no current support for multiple public keys of the same principal. This 
extension should be trivial by adding more than one signature in the handshake. 

• Added tunneling support: we allow the responder to notify in its first handshake 
message that it wants to relay the session. Tunneling is described below (see 
"Support for tunneling" on page 1 49) . When tunneling is indicated, the responder 
might not have to prove the tags requested. 

• Randomized Session Parameter Indices (SPIs) . We want SPIs to be hard to 
guess, to avert denial-of-service attacks. If SPFs are predictable, it is too easy to 
flood the client/server with fatal alert messages. At the same time, we want to be 
able to pay attention to non-authenticated alerts during the handshake (handling 
alerts is described in (see "Handling alert messages" on page 145)). 
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Figure 10 Key agreement protocol 



Initiator 



Responder 




Figure 10 shows the key agreement interactions and corresponding state machines 
of the handlers that control these interactions. These state machines are embedded 
in the state SET_UP in Figure 9. Sub-states READY and DEAD are not necessarily 
related to the ones in Figure 9. For example, killing the handler does not mean that 
the session will die. It is perfectly normal that the handler will terminate when the 
key agreement finishes successfully, and the cipher suite gets "instantiated" in the 
session. 

A quick summary of the messages sent during the handshake: 

• HskRequest: a request from either party to re-negotiate a session 

• HskStart: a request (or acknowledgement) from the client to the server to start 
a session. It contains the elliptic curve and cipher suite list suggested, the SPI at 
this end, a hint on the tags that the server should prove, a hint on the operations 
that we want to perform, and a public Diffle-Hellman (DH) key. 

• HskReply: a reply to the previous HskStart from the server to the client It 
contains the cipher suite chosen, the SPI at the server end, whether the server is 
a relay, certificates to prove the requested tags, a hint of tags that the client need 
to prove, a public DH key and a signature. 



Developer Release X.03.03.00, September 2000 



141 



Session Layer Security Protocol (SLS) 



Communication 



• HskFinish: last Handshake message from client to server. It contains certificates 
to prove the requested tags and a signature, 

• Alert: notify the other end of a failure of the key agreement. 

We made the Initiator and Responder state machines similar by always introducing 
a HskStart message. If the protocol is started by the Initiator the HskStart is 
generated locally. Otherwise it will be generated by the Responder and transmitted 
through the network. We pay attention to alerts and " incorrect" messages that have 
valid random SPI, so we can end the session at any time during HandShake. 

The protection layer 

This term is used for the set of instances of encryption/decryption, hashing and 
authentication algoritiims, along with the particular key-values, to be employed in 
a session. The protection layer is established through the HandShake phase. 

Elliptic Curve Cryptography is used for the initial Diffie-Hellman shared secret 
negotiation instead of modulus exponentiation. The handshake has established an 
elliptic curve (in an integer space) and each party has chosen a point at random on 
this curve, which he keeps entirely secret. Call these two points U and V. They are 
private keys. A function f generates two other points f (U) and f (V) , on the same 
curve. These are public keys, and are exchanged, (Inverting f, to find the argument 
from the function value, is not believed to be practicable for our current choices of 
curve and off.) The two parties both check that the points they receive are valid 
points on the curve. There is a function g such that: 

g[U, f (V)] = g[V, f(U)] = Z 

This is the shared secret, which is used to generate the authentication and 
decryption keys as described below. 
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Key generation algorithm 

For details of key-generation see {Ferguson, Section 4,]. Four fixed byte-arrays are 
used as follows: 

array A - for the key K^^ that authenticates client to server 
array B - for the key Kg that authenticates server to client 
array C - for the key Kc that encrypts client's messages to 
server 

array D - for the key that encrypts server's messages to 
client . 

The keys are symmetric, so Kq is used to decrypt messages from the client, as well 
as to encrypt diem; likewise for messages from the server. is used both to 
create and to verify the client's HMAC s, and Kg for the server s. 

The keys are derived from the byte-arrays as follows. The shared secret Z (or a 
function of it) is expressed in a fixed byte-array. This is appended to each of arrays 
A to D, giving byte-arrays which we will call Key_array A, B etc. For example, 
Key_array A = array A | Z, 

The hash function h is applied recursively to each Key_array. From the Key_array 
s, byte-arrays Sq, Sj, s^ are created, obeying: 

So = h(s) 

Sn = h(so I sil . . . |sn.i|s) (n >= 1) 

Repeated recursion generates longer and longer byte-arrays as the argument to h. 
There are two target lengths: for the authentication keys and Kg, and for 
the encryption keys and Kd, determined by the corresponding algorithms. For 
each key, recursion proceeds till the length of So|si|...|s}, equals or exceeds the target 
length. The first or L£ elements make up the key. 



Cipher suite support 

The encryption algorithms currently supported are Blowfish with a 128 bit key, and 
triple DES with three independent keys for encryption. Blowfish is the 
recommended cipher because of its speed but 3DES is the conservative choice. Also 
only CBC mode and PKCS 5 padding is supported. 
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Our current hash algorithm is SHA-1 and our MAC algorithm is an HMAC 
constmction based on SHA-L 

SPKI certificates are signed/verified using ElGamal with a 768-bit key as default. 
RSA with a 1024 bit key can be used if the client prefers. (All the named algorithms 
are explained in [ScJweier\.) 

Authentication of messages 

See [Menezes, van Oorschotand Vanstoneip2S5\ and [Ferguson, Section 4.] 
A hash is generated from the appropriate authentication key (Ky^ or Kg above), 
selected fields of the PDU header, and the PDU body. This is ±e MAC: it has a fixed 
length (of 20 bytes in our implementation). It is pre-fixed to the PDU body. If the 
encoding type is SECURE_DATA, the resulting string (MAC + PDU body ) is 
encrypted using Kc or K^. The resulting encrypted string we call Q.The PDU 
transmitted will consist of: 

• PDU header 

• PDU body + MAC if type is PROTECTED_DATA 

• Encrypted string Q if type is SECURE_DATA 

For the recipient to check the message, if the type is SECURE.DATA, it begins by 
decrypting Q, using Kq or Kj) as before. This gives a string: MAC + PDU body. The 
selected header fields, the PDU body (without the MAC) and the authentication key 
Ka or Kb are input to the same hash algorithm to generate a second MAC. This is 
compared with the MAC received in the message: if they are unequal, the message 
is not authentic. 

The PDU header fields omitted from the MAC derivation are: 
toAddress, fromAddress, route. 
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Handling alert messages 

During the key agreement protocol the default is to pay attention to non- 
authenticated alert messages that have the correct random SPL These identifiers 
are sent in clear, so if the attacker listens to all our traffic and sends fatal alerts with 
the right SPI before the other party responds, it will still stop the session set-up. 
However, this attack would be much easier if we had a predictable SPL The attacker 
could just flood the system with fatal alerts with typical SPIs. In SLS this problem is 
more evident than in SSL, because of the independence of the session from the 
transport. In this case we cannot make the assumption that it takes some effort to 
hi-jack the transport, as is the case for a TCP socket in SSL 

If we want to disable this type of attack completely, we could ignore all non- 
authenticated alerts and rely on timeouts to close failed sessions. This is not the 
default. The convenience of quick and detailed notification of session set-up failure 
is believed to be more important than countering an impractical denial-of-service 
attack. The attack can always be done at transport level anyway. 

In any case, after a session is established only authenticated alerts are respected. At 
that point many messages with the SPIs in clear have been exchanged, and the 
randomization does not help much. 

Alert messages can be fatal, forcing the other end to close the session, or warning, 
that in our first implementation are just logged. We support both internal alerts, 
generated as a side-effect of a PDU handling, and external alerts, those explicitly 
sent by the client. It is recommended however to avoid sending external alerts and 
rely on internal ones as much as possible. The alert codes used in SLS are described 
above (see "Alert" on page 122). 
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Timeouts description 



Figure 1 1 Session timeouts and state transitions 
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Tsetup(OFF) 




f DEALWrrH ^ 
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There are three built-in timeouts associated with a session: 

• Tsetup: sets the maximum time taken by the key agreement protocol used 
in the SET_UP state. After that time the session becomes DEAD. 

• Tsession: sets the maximum life expectancy of session. This value is the 
minimum of a fixed value (common for all sessions), and the life- 
expectancy of the certificates negotiated during the key agreement. After 
that time the session becomes DEAD. 

• Trekey: sets the maximum time allowed before forcing a rekey operation 
on the session. Rekeying is currently not supported, and Trekey is set to 
infinity. 

Figure 11 describes the behavior of the timeouts in relation to the session states. 
Tsetup sets a limit on the time spent on the SET__UP state, but it is reset after a 
transition to the READY state. Tsession limits the maximum time spent on the 
READY state. When Trekey expires we initiate the rekey and reset the timer, but 
this does not imply a state transition. Clearly, Trekey is only useful if it is smaller 
than Tsession, otherwise the session will never re-key. 
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Re-keying (not currently supported) 



Figure 12 Rekey protocol. 
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After the session has been established it is possible to change the key used in the 
cipher and MAC operations by sending a REKEY message. However, this new key 
has to be based on the original shared secret negotiated using Diffie-Hellman (we 
do not re-run the key agreement protocol) . Therefore, the re-key operation does not 
extend the life of the shared secret, only of the derived keys. In particular, the new 
key is obtained by exclusive-or of the first four bytes of the shared secret with a 
random integer before re-running the key generation algorithm. The one-way 
function used in that algorithm ensures that it is difficult to guess the next key, even 
if you know the previous one. The integer xor-ed with the shared secret is 
transmitted inside the REKEY message. 

Figure 12 shows the basic protocol to re-key a session. Node B decides that it wants 
to start a rekey, so it generates a random number (2322) and sends a REKEY 
message with it. After that it re-keys the "send part" of its cipher suite right away, 
so the next message sent will be encrypted with the new key. When the REKEY 
message arrives to node A this node changes its "handle parf of the cipher suite to 
the new derived key. Then it checks that the message is a request and not a reply 
(the rekey was not initiated by him) and sends a REKEY reply message with 
possibly a different random integer (8898), changing the "send part" of its cipher 
suite too. When the reply message arrives to B, this node will update the "handle 
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part" of their cipher suite but it will not rekey the send part" again because the 
message was tagged as "reply\ 

The important point of the protocol is that all the state is encoded in the messages. 
Provided that messages are not re-ordered, the receiver always has the right key to 
decrypt the message. It does not have to remember old keys or interrupt the service 
during re-keying. This avoids the need of an extra state in the protocol for re-keying. 



Support for session scavenging 

Figure 13 Ping protocol 
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SLS needs an external mechanism to detect that the other party in the session is no 
longer active. This is required because of the independence of transport and session 
"lives". We cannot assume that the underlying transport will detect that the other 
party abandons the session. The transport won't necessarily send a TCP keep-alive 
message, for example. We have to provide that service at a higher level. 

Figure 13 shows the basic support provided for session scavenging. An external 
client can check whether the session is active by forcing its endpoint to send a PING 
message and resetting a flag that indicates a reply ping arrived. If the reply ping 
arrives the flag is set. After a certain time the client checks whether the flag is set, 
indicating whether the other end is still alive or not. 
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Support for tunneling 

In SLS tunneling a PDU contains in its payload another PDU, so messages are sent 
using another SLS session as transport" . When the initiator sends the first protocol 
message, (HandShakeStart in the current implementation), the responder might 
reply that it is not the final end-point, so it cannot prove what was requested, and it 
wants to be a relay instead. At that point the cUent can decide whether to continue 
the key agreement or not If it continues it will get a ready session that was 
negotiated as a "relay** and it can use that session to negotiate another one to the 
end-point. If this new end-point also wants to be a relay the process repeats. 
Typically the maximum depth of session nesting is limited to a fixed value to avoid 
a denial-of-service attack. As implemented, the Session objects are stacked. An 
initial session (A) is connected to the transport; a session B nested in A is 
"connected" to A, and so on. However arranged, it should be transparent to the 
client. 

Figure 14 shows how to send messages from client to server and back after a nested 
session via an SLS gateway has been established. The diagram shows sender SPIs 
as initial characters with a colon, such as "A:" or "B:" The wrapped PDUs are 
bracketed. When a PDU passes through a session a layer of encryption is applied or 
removed. This is not shown in the diagram. 

A session will perform automatic wrapping of a PDU inside another PDU while 
sending when: 

• the sender SPI is valid (>0) 

• the sender SPI does not match the one the session is going through (we use 
sender and not receiver SPI because the receiver one is not guaranteed to be 
unique). 

In the current implementation, a PDU to be tunneled is initialized with an invalid 
sender SPI of -1. So session B just changes the sender SPI to "B". When the PDU is 
passed to session A, the conditions for vio^apping are satisfied. During the wrapping 
the addresses of the inner PDU are copied into the header of the external PDU. This 
is given the message-type TUNNEL. The resulting TUNNEL PDU gets unwrapped 
when it is handled by session A in the gateway. The reply is wrapped by session A 
in the gateway, and unwrapped by session A at the client end. This is default 
behavior that can be overridden by a custom handler. 
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Figure 14 Tunnelling SLS sessions 
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An important feature of the tunneling implementation is that a session can be used 
to tunnel messages regardless of whether the session was negotiated as a relay 
session or not. The opposite is also true, we can send non-tunnelled messages for a 
session that requested to be a relay session. In fact, how sessions are created is 
orthogonal to what type of messages can be sent through them. This simplifies the 
re-use of sessions but: 

• It can't be assumed that a message received in a normal session was not 
tunneled. 

• Tunneled messages, which may have several layers of v^apping and encryption, 
can not be assumed to have traversed a firewall, and are not necessarily any 
more secure than normal messages. 



Core to core communication 

Two e-speak cores can exchange core-managed resources and resource metadata. 
The exchanges comprise import and export of resources. They are needed for 
several reasons, including the following. 

• A resource cannot be discovered in a vocabulary on an e-speak core unless the 
vocabulary has been registered on that core. If the vocabulary was created on 
another e-speak core, it is registered by importing it. 

• A resource cannot be registered in a contract on an e-speak core, unless the 
contract itself has been registered on that core. If the contract was created on 
another e-speak core, it is registered by importing it. 

• Resource metadata can be imported into an e-speak core, to cache it. This will 
make lookup of those resources faster. 

Two core-managed resources handle communication between e-speak cores. 

• The Connection Manager CM, sets up the initial connection, manages it and 
closes it dovm. The ESName for the CM on any given e-speak core is: 
es://<server>/CORE/ConnectionManager 
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• The Remote Resource Manager (RRM) is responsible for managing metadata: 
importing and exporting resources from the remote e-speak core. The ESName 
for the RRM on any given e-speak core is: 
es://<server>/CORE/RemoteResourceManager 



The Connection Manager provides the core-to-core connection handling APIs, Each 
connection is associated with a Protection Domain, Outbox and an Inbox. The 
inbox and outbox along with the Router form the message forwarding subsystem to 
the remote core (see Figure 7), 

The core-to-core connection can be a secured channel: SLS messages may be 
exchanged to set up a secure chanel 

class connectionManager{ 

public synchronized String openConnection (String coreUrl) ^ 
throws UnknownHostException 

public synchronized void closeConnection {String conID) 
throws UnknownHostException 

public synchronized CMArg closeConnectionFromRemote (CMArg 
cmArg) 

throws UnknownHostException 

public synchronized ESArray getConnections ( ) 



1 The coreUrl should be type ESname. in the current implementation it is type String. 




RRM: Remote Resource Manager 
CM: Connection Manager 



Figure 15 Core-core communication components 
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CM Methods: openConnection() 

The openConnectionO invocation is synchronous. The caller has to wait until the 
openConnectionO returns or times out (the current default time out period is 10 
seconds). The parameter is the URL of the remote core s root frame: a URL of the 
form es://host 

When the Connection Manager executes this function it sends a PDU message to the 
remote core. The toAddress of the PDU is set to es://host/CORE, (Note that only 
"esif/hosf is the argument passed by the caller of openConnectionO.) ThePDUisa 
messagePorResource with a payload type of METHOD_CALL: the payload field is 
an instance of methodCall. The methodCalLinterface is Xore" and the method field 
is "bootstrap". The fromAddress is set to es://<localCore>/CORE, where 
<localCore> is the host and port for the Connection Manager s e-speak core.2 

The messageType field of PDU is set to HANDSHAKE for this request in the current 
implementation. It should, for consistency, be APPLICATION_MESSAGE. 

Once the message has been sent, the Connection Manager waits for a reply PDU 
message. The remote core receiving the message replies with a bootstrapRepIy 
message (see "Initial Connection to the Core" on page 130). In the current 
implementation this reply is ignored. 

Next the Connection Manager sends a " negotiate" message to the remote core. This 
consists of an empty messagePorResource instance (payloadType is set to OBJECT 
and the payload contains the null object). The toAddress of the PDU is set to es:// 
host/CORE/ConnectionManager. The fromAddress of the PDU is set to es;// 
<localCore>/CORE/ConnectionManager, 

Once this message is sent the Connection Manager waits for a reply from the remote 
Connection Manager. In the current implementaiton this reply is ignored. 

The returned value of openConnection is a String denoting the server and port of 
the remote core to which a connection has been made. Thus a connection to es:// 
foo.bar.com:8000/ returns a String: "foo.bar.com:8000" . This String can be used to 
identify the connection for later connection management operations. 



2 In the current implementation all URLs created by the connectionManager begin with "tcp://" 
instead of "es:/r 
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Only one connection exist between 2 cores. Once the connection is established 
subsquent openConnectionQ requests with the same parameter have no effect 

CM Methods: proposed future negotiation 

The " negotiate" message is a place holder for future extensions. The intended future 
behavior is as follows. 

1. Initiator builds a negotiation proposal, and sends the proposal to the remote core. 
The offer includes parameters such as Core Version, e-speak version and PDU size 
(for buffering, fragmentation and reassembly). 

2.The remote core then builds an offer based on the proposal and send the offer to 
the initiator. 

S.The initiator then builds the agreed upon offer and sends the final offer to the 
remote core. 

CM Methods: closeConnection() 

The closeConnectionO function performs a graceful close of connection between 
the cores. The closeConnection API sends a "close" message to the remote core and 
requests to cleanup the resources allocated to this connection. Upon receiving the 
close request message from a remote core the Connection Manager initiates the 
clean-up process, thereby deallocating the resources assigned for the connection. 

The parameter conID to closeConnection 0 is the String previously returned from 
openConnectionQ. When closeConnectionQ is invoked the Connection Manager 
sends a PDU containing a messageForResource instance to the remote Connection 
Manager. The MessageForResource has a payloadType of METHOD_CALL. The 
interfaceName is "ConnectionManagerlnterface" and the methodName is 
"closeConnectionFromRemote\ The parameter CMArg is defined as follows: 

class CMArg { (ESF) 
String localXJRL; 
String remoteURL; 

int type; // CL0SEC0NNECTI0NREQUEST=1 CL0SEC0NNECTI0NREPLY^2 
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The localURL field is set to the host+server port for the sending core for example: 
'*initiator.bar.com:8080\ The remoteURL field is set to host+server port for the 
remote core. The type is set to CLOSECONNECTIONREQUEST. When the remote 
core receives this message, it can use the localURL, remoteURL pair to identify the 
connection. The remote core sends a messageForResource with a payloadType of 
METHOD^RESULT. The Ob field of the MethodResult class is an instance of 
CMArg. The localURL and remoteURL are unchanged, but the type field is set to 
CLOSECONNECTIONREPLY. Having sent this, the remote core closes the 
connection. When the initiating core receives this reply, it closes the connection. 

CM Methods: getConnections 

The function getConnections 0 returns the state of current connections. Each 
element of the returned ESArray is a String of the formed by the IP address of the 
remote host and the port number on which the remote e-speak core is located 
separated by a colon, e.g.: "host.foo.comrSOOO" 



Remote Resource Manager 

The Remote Resource Manager (RRM) handles metadata related functions. It 
provide the capability to export and import resources to and from remote e-speak 
cores. 



RRM Message Class 

Instances of the class payloadForRRM are used as arguments or returned by the 
RRM: 

class payloadForRRM{ (ESF) 
int payloadType; 
boolean topLevel; 
int importExportMode ; 
byte [] context PDU; 
ESArray resourceTable; 
ESArray tablesArray; 

The following are permissible values for payloadForRRM,payloadType: 

EXPORT_REQXJEST-0; //Export Request 
EXP0RT_REPLY-1; //Export Reply 
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IMP0RT_REQXJEST=2 ; //Import Request 
IMP0RT__REPLY-3; //import Reply 

UPDATE_EXP0RTED_RES0URCE_REQUEST=4 ; //Update Export Resource 
Request 

UPDATE_EXP0RTED_RES0URCE_REPLY=5; //Update Export Resource 
Reply 

UPDATE_IMP0RTED_RES0URCE_REQUEST=6; //Update Import Resource 
Request 

UPDATE_IMP0RTED_RES0URCE_REPLY=7; //Update Import Resource 
Reply 

UNEXP0RT_REQUEST=8; //Unexport Resource Request 
UNEXP0RT_REPLY-9; //Unexport Resource Reply 
IMPORT_ERROR=10; //Import Error 
EXPORT_ERROR=ll; //Export Error 

RRM Class: 

class RemoteResourceManager { 

void exportResource (ESName esname, boolean topLevel, int mode. 
String server) 

throws NameNotFoundException, StaleEntryAccessException 

PayloadForRRM importResourceFromMsg (PayloadForRRM rrmPayload) 
throws RemoteException 

void import Resource (ESName esname, boolean topLevel, int type, 
String server) 

throws ImportFailedException 

PayloadForRRM exportResourceAsMsg {PayloadForRRM rrmPayload) 
throws StaleEntryAccessException, NameNotFoundException, 
RemoteException 

void unExportResource (ESName esname. String server) 
throws Re que s tNo t De 1 i ve r e dExc ep t i on 

PayloadForRRM unExpor t Res our c e Fr omMsg ( PayloadForRRM rrmPayload) 

throws NameNotFoundException, 

StaleEntryAccessException, 

QuotaExhaustedException, 

InvalidNameException, 

PermissionDeniedException, 

RemoteException 

void updateExportedResource (ESName esname, boolean topLevel, int 
mode. String server) 
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throws StaleEntryAccessException, 
NameNotFoundException, 
RequestNotDeliveredException, 
ExportFailedException 

PayloadForRRM updateBxportedResourceFromMsg (PayloadForRRM 
rrmPayload , 
String fromServer ) 

throws NameNotFoundException, 

S taleEntryAccessExcept ion , 

Permiss iouDeniedExcept ion , 

InvalidValueException, 

UpdateFailedException, 

RemoteException 

void upda te Import edRe source (ESName esname, boolean topLevel, int 

type, String server) 

throws NameNotFoundException, 

StaleEntryAccessException, 

RequestNotDeliveredException 

PayloadForRRM update Import edResourceFromMsg (PayloadForRRM 
rrmPayload) 

throws RemoteException 

void exportOnConnecting (ESName esname, boolean toplevel, int 
type) 

throws NameNo tFoundExcept ion ; 
} 

RRM Methods: exportResource() 

void export Re source (ESName esname, boolean topLevel, int mode, 
String server) 

throws NameNotFoundException, StaleEntryAccessException 

The function exportResource exports the resource identified by esname to the 
server identified by server. The server parameter is a String of the form 
hostnamerport, for example "foo.bar,com:8080\ The boolean topLevel indicates 
whether this is to be a recursive export (topLevel = false) or not (topLevel = true). 
A recursive export will export all resources that are referenced in the metadata of 
the resource identified by esname (vocabularies, contracts and the like). The mode 
parameter indicates whether this is to be export by reference or export by value. 
Export by reference copies the metadata but not the resource state. Any invocation 
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of the exported resource will invoke the same copy. Export by value exports the 
resource state as well as its metadata: an invocation of the resource on the remote 
core will result in an invocation of its own copy of the resource. Recognized values 
for mode are BY_VALUE (0) and BY_REFERENCE (1). Export by value is only 
supported for Core-managed Resources, The RRM will invoke 
importResourceFromMsg on a remote RRM to export the resource to that RRM, 
The payloadForRRM will have a payloadType field set to EXPORT_REQUEST, 

RRM Methods: importResourceFromMsg () 

PayloadForRRM importResourceFromMsg (PayloadForRRM rrmPayload) 
throws RemoteException 

The function importResourceFromMsg is invoked by a remote RRM (B) to tell RRM 
(A) to import the resource (s) contained in the argument rrmPayload, an instance of 
payloadForRRM. The payloadType field is set to EXPORT_REQUEST. The topLevel 
field is set to false if the import is to be recursive. The ImportExportmode field is 
set to BY^VALUE (0) or BY.REFERENCE (1). The contextPDU is not used by RRM 
A; it is returned to RRM B. The intent of this field is to enable RRM B to identify the 
context (typically an attempt to send a message) that caused it to invoke 
importResourceFromMsg. 

The ESName of each resource being exported is in rrmPayload.resourceTable. If 
the export is not recursive, this will have only one element: the ESName of the 
original resource passed to RRM A as the argument to exportResourceQ. If the 
export is recursive, this ESArray will contain all the ESNames of resources included 
in the metadata of the original resource and all the resources included in the 
metadata of these resources and soon on. If the export is BY.VALUE then resources 
included in resource state will also be included in the resourceTable, 

Each element of rrmPayload.tablesArray is itself an ESArray. There is an ESArray 
in tablesArray corresponding to each element in resourceTable. Each ESArray in 
tablesArray consists of four elements. 

Taken together these define the resource metadata and state for the resource 
identified by the ESName in resourceTable: 

• short typeCode 

• ResourceSpeciflcation spec 
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• ResourceDescription desc 

• Object resource 

The following are permissible values for typeCode; 

INBOX_CODE = 0 
META_RESOXJRCE_CODE = 1 
PROTECTION_DOMAIN_CODE = 2 
RESO'aRCE_FACTORY_CODE = 3 
CONTRACT_CODE = 100 
CORE_DISTRIBUTOR_CODE = 110 
IMPORTER_EXPORTER_CODE ^ 120 
MAPPING_OBJECT_CODE =140 
NAME_FRAME_CODE = 150 
REPOSITORy_VIEW_CODE =160 
SECURE_B0OT_C0DE = 170 
SYSTEM_MGNITOR_C0DE =180 
VOCABUIARY_CODE = 190 
CORE_MANAGEMENT_SERVICE_CODE = 200 
DEFAULT_VOCABULARY_CODE = 210 
DEFAULT_CONTRACT_CODE = 220 
FINDER_SERVICE_CODE =23 0 
C0NNECTI0N_MANAGER_C0DE =240 
REMOTE_RESOURCE_MANAGER_CODE = 250 
EXTERNAL_CODE = 1000 

EXTERNAL_RESOURCE_CONTRACT_CODE = 1001 

ResourceSpecification and ResourceDescription are defined in Chapter 3, 
"Resource Data, Searches & Vocabularies". 

The resource field is omitted if the resource identified by the ESName in 
resourceTable is an external resource (typeCode = EXTERNAL_CODE). Otherwise 
the resource field is an instance of the Core-managed resource specified. It will 
contain the data members defined for this Core-Managed Resource type in Chapter 
4, "Core-Managed Resources\ The resource field is included even if the export 
mode is BY.REFERENCE. 

RRM Methods: importResourceQ 

void itnportResource (ESName esname, boolean topLevel, int type, 
String server) 

throws ImportFailedException 
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This method instructs the RRM to import the named resource from the server 
identified by the String server (the format of this String is hostport). The boolean 
topLevel is set to false if the import is to be recursive. Permissible values of the 
argument type are BY.VALUE or BY.REFERENCE. When this function is invoked 
on the RRM it sends a message to the remote RRM on the core denoted by the server 
parameter. This is a messageForResource, containing an instance of methodCall 
with interfaceName: 'RemoteResourceManagerlnterface", methodName: 
"exportResourcePromMsg" and a single element in the argument array, of type 
payloadForRRM. The payloadType for payloadForRRM is IMPORT_REQUEST. The 
importExportMode is set to BY„VALUE or BY.REFERENCE. The contextPDU field 
is used by the RRM to identify the context for the reply to this message. Typically it 
contains a serialized PDU. The resourceTable contains a single element: the esname 
parameter passed in the call of importResource. 

RRM Methods: exportResourceFromMsgO 

PayloadForRRM exportResourceFromMsg( PayloadForRRM rrmPayload) 
throws StaleEntryAccessException,NameNotFoundException, 
RemoteException 

The function exportResourceFromMsg is called from a remote RRM in response to 
an invocation of importResource on the remote RRM. The rrmPayload parameter contains 
the data defined in the description of importResource. The returned PayloadForRRM is sent 
in a messageForResource which contains an instance of methodResuIt. This 
PayloadForRRM has type IMPORT_REPLY, The importExportmode, topLevel and 
contextPDU fields will be diose contained in the original rrmPayload. The resourceTable and 
tableArrays contains the list of ESNames of resources, and their metadata and state as 
described in the description of importResourceFromMsg. 

RRM Methods: unExportResource() 

void unExportResource (ESNarae esname, String server) 
throws RequestNotDeliveredException 

The function unExportResource causes the RRM to try to unexport the resource 
from the remote e-speak core identifed by server (format "hostiport"). It does this 
by sending and instance of methodCall with mterfaceName 
"RemoteResourceManagerlnterface", methodName "unExportResourceFromMsg" 
and a single element in the argument array of type payloadForRRM. The 
payloadType for payloadForRRM is UNEXPORT.REQUEST. The topLevel and 
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importExportMode fields are not used for this request. The resourceTable field 
contains a single element: the esname parameter to the function 
unExportResource. The tablesArray field is empy. 

RRM Methods: unExpoitResourceFromMsgO 

PayloadForRRM unExportResourceFromMsg (PayloadForRRM rrmPayload) 

throws NameNotFoundException, 

StaleEntryAccessException, 

Quo t aExhaus t edExcep t ion , 

Inval idNameSxcept ion , 

PermissionDeniedException, 

RemoteException 

The unExportResourceFromMsg is invoked from a remote RRM in response to a 
call of unExportResourceFromMsg on the remote RRM. The rrmPayload contains 
the data defined in the description of unExportResourceFromMsg. The intent is 
that the RRM receiving an invocation of imExportResourceFromMsg should 
remove the resource contained in rrmPayload from its repository, 
ThePayloadForRRM instance returned contains a payloadType of 
UNEXPORT_REPLY and the contextPDU passed in the rrmPayload parameter. All 
other fields are unused. 

RRM Methods: updateExportedResource() 

void updateExportedResource (ESName esname, boolean topLevel, int 

mode. String server) 

throws StaleEntryAccessException, 

NameNotFoundException , 

Reque s t No t De 1 i ve r e dExcep t i on , 

ExportFailedException 

The effect of calling the updateExportedResource function is very similar to calling 
ExportResource. The difference is that the RRM will invoked the 
updateExportedResourceFromMsg function on the remote RRM (instead of 
ExportResourceFromMsg) and the payloadType of the PayloadForRRM instance 
passed as a parameter in the remote invocation will be set to 
UPDATE_EXPORTED_RESOURCE_REQUEST. 
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RRM Methods: updateExportedResourceFromMsgO 

PayloadForRRM updateExportedResourceFromMsg (PayloadForRRM 
rrmPayload , 
String froraServer ) 

throws NameNotFoundException, 

StaleEntryAccessException, 

Permiss i onDeniedExcep t ion , 

InvalidValueException, 

UpdateFailedException, 

RemoteException 

The function updateExportedResourceFromMsg is invoked by a remote RRM when 
it wishes to update resources which have been exported previously. The intent is 
that the RRM receiving the call of this function replaces the metadata (and the state 
in the case of an export BY_VALUE) of each resource in the resourceTable in 
rrmPayload with the metadata and state contained in tablesArray. Only resources 
that have already been registered will have their metadata and state updated. The 
PayloadForRRM returned as the result will have the contextPDU of the rrmPayload 
parameter and a payloadType of UPDATE_EXPORTED_RESOURCE_REPLY. All 
other fields will be ignored by the remote RRM that invoked 
UpdateExportedResourceFromMsg, when it receives this result 

RRM Methods: update I mportedResource() 

void updatelmportedResource (ESName esname, boolean topLevel, int 

type, String server) 

throws NameNotFoundException, 

StaleEntryAccessException, 

Regues tNo tDe 1 i veredExcept i on 

The UpdatelmportedResource function is similar to the importResource function. 
The major difference is that the RRM has previously imported the resource 
identified by esname. The RRM will invoke the updatelmportedResourceFromMsg 
on the remote RRM identified by the String server (host:port) . The PayloadForRRM 
passed as a parameter in updatelmportedResoruceFromMsg has payloadType of 
UPDATE„IMPORTED_RESOURCE„REQUEST and will have a single element in 
resourceTable: the ESname of the resource that needs updating. Note that this may 
not be the same ESName that is received as a parameter to 
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updatelmportedResource, it must be the ESName used to identify the Resource 
when it was originally imported. So the RRM must remember this information about 
imported resources if it is to request updates of metadata. 

RRM Methods: update I mportedResourceFromMsgO 

PayloadForRRM updatelirportedResourceFromMsg (PayloadForRRM 
rrmPayload) 

throws Remote Except ion 

The function updatelmportedResourceFromMsg is invoked by a remote RRM when 
it has received an invocation of updatelmportedResource and needs to update a 
resource s metadata (and possibly state). The rrmPayload will contain the data 
described in the descripion of updatelmportedResource above. The 
PayloadForRRM returned from the updatelmportedResoruceFromMsg function 
has a payloadType of UPDATE JMPORTED_RESOURCE_REPLY. The topLevel. 
importExportMode and contextPDU fields will be the same as in the rrmPayload 
parameter. The resourceTable field and tablesArray respectively contain the 
ESnames and metadata (and possibly state) of the resources to be updates. Note 
that even though a single resource ESname is all that is contained in the rrmPayload 
parameter, the result can contain many ESnames if the topLevel flag is set to false 
(indicating recursive import/export). 

RRM Methods: exportOnConnectingO 

The resource is added to the list of resources to be exported when connection is 
established. The parameter esname is the ESName of the resource to be exported. 

The parameter toplevel is set false if export is to be recursive. 

The parameter type indicates the type of export. It can take the value BYVALUE (0) 
orBYREFERENCE(l). 

Restrictions on import and export of core managed resources 

The following Core-managed Resources cannot be exported or imported. 

• Protection Domain 

• Meta Resource 
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• Resource Factory 

• Inbox 

• System Monitor 

• External Resource Contract 

The Account Manager cannot be exported by value, only by reference. 

Other Core-managed Resources have restrictions when exported by reference. In 
particular, such a Resource cannot be used as part of message processing as shown 
in Table 10 » 

Table 10 Core-managed Resource export restrictions 



Resource 


Pass by reference restrictions 


name-frame 


Cannot be used as a component of an ESName sent to the 
Core for name resolution 


Repository View 


Cannot be used in a Search Recipe 


Resource Contract 


Cannot register a Resource in this Contract 


Vocabulary 


Cannot be used in a Search Recipe 



Removing imported resources (informational) 

The Connection Manager provides the closeConnectionQ function to perform a 
graceful shutdown of a connection. The Connection Manager builds a close 
connection message and sends the message to the Connection Manager of the 
remote core, requesting the connection cleanup process. In the ciurent 
implementation, the Connection Manager on the remote core removes the 
Protection Domain, Outbox and other resources allocated to the connection. 
Removing the Protection Domain used for the connection will remove all resources 
that have been imported from the connection (as they are registered in this 
Protection Domain). 

The initiating core also performs similar clean up process. The Protection Domain, 
Outbox assigned to the connection are removed. 
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ESnames denote an access path to a resource. ESnames conform to the format and 
grammar defined for Universal Resource Identifiers (URIs) [see RFC 2396[. 
ESNames are therefore URIs and mores specifically, since they denote the access 
path for the resource, ESNames are also Universal Resource Locators (URLs). 
ESNames have the following format. 

es://<host>/<relative path> 

The host part of an ESName is either the host name or the IP address of the host on 
v^hich the e-speak core is located together with an optional port number. If the port 
number is not specified, the current implementation will throw an exception. 
Discussions are underway with L\NA for a standard port number to be assigned. 

The full form of an ESName (es://<host>/<relative path>) is known as an absolute 
ESName. Subsets of this syntax also denote ESNames (see "ESName BNF" on page 
169). However, it may not be possible to resolve such ESNames if we do not have 
the necessary context. 

The relative path component of an ESName must be unique on the given e-speak 
core. The path is relative in the sense that it is given a global context by the <host> 
element of the ESName. If the <host> element is missing (e.g. es://path or es:/path), 
then the resolver must decide the global context in which to begin resolution. 
Usually the global context is assumed to be the current host 

The path consists of a set of Strings separated by Y , for example Vb/c" . The path 
is resolved by taking each String element in order and resolving that in the current 
name-frame. If this returns a name-frame the next element is resolved in that name- 
frame. The process continues until there are no more elements in the path in which 
case we have resolved the ESName to the intended resource. The first element will 
be resolved in the root name-frame of the e-speak core denoted by the server part 
of the ESName. For example, taking "a/b/c", "a** is resolved in the e-speak core s 
root name-frame to return a name-frame which we denote NF(a) . Next b is resolved 
in NF(a), to return a name-frame which we denote NF(a b). Finally c is resolved in 
the name-frame NF(a b). 

If a String element of the path component other than the final component fails to 
resolve to a name-frame, name resolution has failed. If the final element fails to 
resolve to a resource, name resolution fails. 
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When a client registers a resource with an e-speak core, the default name-frame for 
that resource, is root name-frame of the client s protection domain. 

If two clients on the same host bind two different resources in their root frames 
under the same relative path (e.g /a/resource) they will have different absolute 
ESnames even though the host part is the same: 

es : / /host/ clientlPDRootFrame/a/resource and 
es : //host/client2PDRootFrame/a/resource 

If a client terminates and its protection domain is not persistent, there will be a 
recursive deletion of all names within the protection domain^s root name-frame. 
This means any URLs handed out rooted in this name-frame will be invalid. To 
overcome this, a resource needs to be bound in a name-frame which is persistent.To 
stop the deletion of a non-persistent protection domain causing a deletion of 
persistent resources, the current implementation prohibits a persistent resource to 
be bound within a non-persistent Protection Domain. 

Core name-frame and core root name-frame 

Every e-speak Core has a Core Name-Frame with the following ESName. 

es : //<hostport>/core 

The names of various core managed resources are bound within this name-frame, 
including vocabularies, contracts and the metaresource. The following names are 
currently used. 

/Core/Me taResource 
/Core/ResourceFactory 
/ Core /SystemMoni tor 
/Core/Finder 

/ Core/CoreManagementService 

/Core/DefaultVocabulary 

/Core/BaseDistributorVocabulary 

/Core/CoreDistributor 

/Core/Connect ionManager 

/ Core/ReTnoteResourceManager 

/ Cor e / Ac count Manage r 

/Core/BaseAccount Vocabulary 

Every e-speak Core has a root name-frame which is denoted: 
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es : / /<hostport>/ 

or, alternatively, assuming the <hostport> part is already known to the resolver: 
es:/ 

The following names are bound in the e-speak Core root name-frame: 
/Core 

/ Cent r a c t Con t r ac t 
/VocabularyContract 

Canonical ESName 

This is the ESName stored in the URL field in the Resource s ResourceSpecification 
(see Chapter 3, "Resource Data, Searches & Vocabularies"), This ESName is 
guaranteed always to be valid as long as the Resource is registered. It does not 
depend on any binding maintained in a Client*s name-frame. Cannonical ESNames 
have the following form: 

es : // <hostport>/proc/resource/<type_string>/<unigue_id> 

The <hostport> field is of the form host name or IP address followed by a port 
number separeted by a " as specified in [RFC 2396i. 

The following are the permissible values of <type_string>, they denote the 
Resource Type (see Chapter 3, ''Resource Data, Searches & Vocabularies") 
"Inbox" 

"MetaResource " 

" Protect ionDomain" 

( "ResourceFactory" ) 

( "ConnectionManager" ) 

( "RemoteResourceManager " ) 

"Contract" 

( "CoreDistributor") 

"ExternalResource" 

"ExternalResourceContract" 

( " ImporterExporter " ) 

( "MappingOb j ect " ) 

"NatnePrame " 

" Repos i t ory Vi e w " 

("SecureBoot ") 

" SystemMoni tor " 

( "AccountManager" ) 
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"Account " 
"Vocabulary" 

( "CoreManagement Service" ) 
" Finder" 

The field <uniquejd> is the Stringified form of a number (in the current 
implementation this is the repository handle). 

The terms bracketed are permissible values of <type_string>, but will normally be 
bound in the Core Name-Frame described above (es://<hostport>/core). If so, they 
will not occur under es://<hostport>/proc/resource. 

Queries and fragments 

Queries and fragments are also allowed in ESNames. A query is the data diat follows 
the in an ESName of the form: 

es ://<host>/<relative path> ? uric* 

A fragment is the data that follows the in an ESName of the form: 

es://<host>/<relative path> # uric* 

The character set uric is defined in [RFC2396i which also specifies constraints on 
the data in queries and fragments. 

Queries and fragments are not used in name resolution and are never interpreted by 
the e-speak core. They are delivered to the resource handler as part of the message. 

ESName class definition 

class ESName { 
String hostPart; 
String [] pathPart; 
} 

The above class defines the hostPart consists of the portion of the ESname from 
es:/r to the first Y . In an ESName the path separator is T , This separates elements 
of the path. Each element of pathPart consists of an element in the path, without 
anyT character. 
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Here is the BNF for ESNames. Please refer to [RFC 2396\ for any element not 
defined directly. 

ESName = [ absoluteESname ( relativeESname ] [ fragment ] 

absoluteESname = es " : " hier_j)art 

relativeESname = ( net_j>ath | abs_j)ath | rel_path ) [ query ] 

hier_part = ( net_path | abs_path ) [ "?" query ] 

netjpath = "//" hostport [ abs_path ] 
abs_path = path_segments 
rel_j)ath = rel_segment [ abs_path ] 

rel_segment = 1* ( unreserved | escaped ( | "@" | | " = " 

I j "$" I ) 

hostport = host [ " : " port ] 
host - hostname | IPv4address 

hostname = * ( domainlabel " , " ) toplabel [ " . " ] 
domainlabel = alphanum | alphanum *( alphanum | ) alphanum 

toplabel ~ alpha | alpha * { alphanum | " - *' ) alphanum 
IPv4address = l*digit " . " l*digit " . " l*digit " . " l*digit 
port = *digit 

path_segments = segment *( segment ) 

segment = *pchar * ( " ; " param ) 
param = *pchar 

pchar = unreserved | escaped | j "@" | j " = " | " + " | 



query 
fragment 



= *uric 
= *uric 
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PDU Marshalling format 

A PDU is transmitted as a 32 bit length (in network byte order), followed by the 
buffer containing the PDU itself. 

All data inside a PDU is marshalled in network byte order. 

• int is a 32 bit integer 

• long is a 64 bit integer. 

• short is a 16 bit integer 

• char is a 16 bit character 

• boolean is marshalled as a single byte (0x01) for true (0x00) for false. 

• String is marshalled as a 1 6 bit length followed by each character in the String as 
16 bits per character 

• byte[] is marshalled as a 32-bit length followed by the bytes. 

• ADR are marshalled by converting them to ASCII canonical s-expressions 
defined in " SPKI BNF Formats" (Chapter 5, ^Access ControF) and then marshalled 
as a byte array using marshalBytes. 



E-speak Serialization Format 

The basic types recognized are byte, short, int, long, float, doiible, and 
string. The four integral types byte, short, int, and long are 1. 2, 4, and 8 bytes 
long respectively, and are always sent most significant byte first. The float and 
doi±)le types are sent just as in Java. The string type is intended to contain text 
rather than arbitrary binary data, and the text must be a valid UTF-8 encoded string 
as per [RFC 227^. It is hoped that "string" will not be confused with 
java.lang.String. 

We also recognize arrays of types. The type foo[] is sent as a length followed by that 
many instances of type foo. If the length is -1, then a NULL is returned. If the length 
is 0, an empty array is returned. Otherwise an array with that many elements is 
returned. 
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A map is sent in the same syntactic way as an array, but there is an implicit Key/ 
value association between pairs of elements; all the evenly indexed elements (0, 2, 
etc.) are Keys, and all the odd indexed elements are values. Some maps may allow 
multiple occurrences of the same Key. 

The length field is encoded in a single byte if the value of the length is 4. .62 
inclusive; the encoding is 129 more than the length. Thus, -1 is sent as the byte value 
128, and a length of 3 is sent as the byte value 132, Lengths from 63..2^3M are sent 
as a 4 byte integer. Lengths below -1 or greater than 2^31-1 are illegal at the present 
time. 

All elements are sent as a signal byte that indicates the type of the object that 
follows, followed by the data for that object. 

Signal bytes are entirely single bytes. They are encoded by literal ASCII characters 
(e.g., A), literal ASCII characters but with the high byte set (char) ('J'+ 128)). 

Here is the Backus-Naur Form (BNF) for " Ob" an object serialized in the e-speak fo 
rmat, using the signal bytes defined currently. 

Ob = » E • , <RSD > I 

'D', <ResourceDescription >| 

'S', <ResourceSpecif ication >| 

* [ ^ <ESUID > I 

'C, <SearchPredicate >| 

»C', <SearchRecipe >| 

' ] ' / <VocabularyDeclaration > | 

, <Preference >) 
' " • , <FilterSpec >| 
'T', <AttributeProperty >| 
'A', <AttributePropertySet >| 
'a' , <Attribute > | 
'B' , <AttributeSet >| 
'V , <Value >| 

, <ValueType >| 
'F', <ESName >| 
* ) * , <ESString > | 
'q', <AttributePredicate >| 
' < ' , <NamedObject > | 

<Prof ileAttributeSet >| 

* > ' , <UserProf ile > | 

'N', <NameSearchPolicy >| 
' . * , <FinderResults > 
' / ' , <FinderContext > 
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'Q', < Cor eE vent >| 
' e ' , <Event > ( 
't\ <EventAttributeSet > 
* Z ' , <ESRuntimeException> 
'z' , <ESException>| 



(char) 


I * z 


•+128 


/ 


<ES Array 




>i 


(char) 


' • s 


'+128 


r 


<ESSet > 


1 




(char) 


'I 


»+128, 


/ 


< Integer 




>i 


(char) 


* J 


'+128] 


/ 


<Long >| 






(char) \ 


'B 


•+128) 


f 


<Boolean 




>l 


(char) 


'y 


•+128) 


t 


<Byte > 1 






(char) 1 


'C 


•+128) 


1 


<Character > 


(char) ( 


'W 


'+128) 


t 


< Short > 






(char) ( 


'F 


+128) 


1 


<Float > 






(char) 1 




+ 128) 


I 


<Double > 




(char) ( 


'S 


+ 128) 


1 


<String > 




(char) ( 


'2 


+ 128) 


» 


<boolean[] > 


(char) { 


•b 


+ 128) 


t 


<byte[] > 




(char) ( 


'c 


+ 128) 


/ 


<char[] > 




(char) ( 


' w 


+ 128) 


/ 


< short [] 


>i 


(char) ( 


'i' 


+ 128) 


/ 


<int[] >| 






(char) ( 


'j' 


+ 128) 


/ 


<long[] > 




(char) ( 


•f ' 


+128) 


t 


<f loat [] 


>i 


(char) ( 




+ 128) 


t 


<do\ible [] 




> 


(char) ( 


' v 


+ 128) 


t 


<Object [] 




> 


(char) ( 


'H' 


+ 128) 


r 


<ESMap >| 







' I ' , <PayloadForRRM > | 
' : ' , <CMArg > I 
• h ' , <RepositoryHandle > | 
• r • , <Contract > | 
'W, <RepositoryView >| 
' V , <Vocabulary > | 
' m ' , <MappingOb j act > | 
' s ' , <NameFrame > | 

, <Binding > | 
• ? ' , <ProtectionDomain > | 
* % ' , <Inbox > I 
' @ • , <ExternalResource > | 
' ^ ' , <SystemMonitor > | 
' + ' , <ResourceFactory > | 
*y * , <Finder > | 
*n*, <ConnectionManager >| 
'd', <RemoteResourceManager > 
' - ' , <CoreManagementService > 
' - ' , <AccountManager > 
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The components for each of the remaining non primitive type are defined in the 
relevant sections of this specification (to do: need to pull these definitions in 
to complete the BNF). 

In the following BNF, the meta-symbol => means '^is sent as." The convention is as 
follows: 

string => string 
Integer => int 
Long => long 

Boolean => byte 
Null => 
ByteArray => byte [] 
ObjectArray => Ob t] 
ESMap => map 
ESArray => Ob [] 
ESSet => Ob[] 
ESList => Ob[] 

ESMap, ESArray, ESSet and ESList in the current implementation are marshalled 
using Java serialization. 
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E-speak defines a set of exceptionsto inform Clients when an error occurs in the 
system. Two classes of exceptions are defined: run-time exceptions and 
recoverable exceptions. 



Run-Time Exceptions 

Run-time exceptions are thrown when programming errors occur. A program 
catching such exceptions may terminate. ESRuntimeException has the 
following subclassed exceptions: 

• CorePanicException is thrown when the Core is unable to process the 
request. Although the Core attempts to notify aU Clients of its inability to 
continue operating, it also repUes with this exception for as long as it can. The 
Core can continue to accept new messages as the problem may be limited to the 
execution of a single message. 

• ServicePanicException is thrown when a service is unable to process the 
request. This can be a terminal error for the service, in which case the service 
exits. Or it can simply mean that the request being processed caused an internal 
error that was not recoverable, and the service accepts new requests. 

• RepositoryFullException is thrown when the request attempted to add 
additional information to the Core's Repository, but the Repository was full. 
This exception can be recovered from if the Client is able to delete one or more 
Resources from the Repository. It is a run-time exception because almost every 
message can possibly throw this exception, and the Client has no guaranteed 
recourse (because some other application can consume the Repository space 
freed up by this Client). 
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• Outof OrderRequestExcept ion is thrown when the state of the system is 
inconsistent with the request, 

• ConnectionFailedException is thrown when the Connection Manager fails to 
establish a connection, details are contained in the exception state. 

• invalidParameterException is thrown by any other programming errors. 
This exception has three subclasses: 

• NullParameterException is thrown where a null parameter was 
supplied but is not allowed. This error is often caused by passing an 
uninitialized object. 

• Inval idValueExcept ion is thrown when a parameter is outside the 
allowed range. 

• Inval idTypeExcept ion tells the programmer that the name specified is 
bound to the wrong type of Resource. 



Recoverable exceptions occur due to a problem with the state of the system. For 
example, when the Client sends a message to request access to a Resource, the 
message may be undeliverable, perhaps because the Handler s Inbox is full. 
Recovery for this case can be as simple as resending the message. 

The base exception is ESExcept ion. This exception is subclassed into three major 
categories: ESLibException, ESInvocationException and 
ESServiceException, 

ESLibException is the base class for client library exceptions. It should not be 
thrown itself but rather a subclass exception.Currendy one subclass is defined. 

• CoreNotFoundExcept ion indicates that a core could not be found to connect 
to. Either change the specification of the core or insure the core is running to 
correct this exception. 



Recoverable 



Exceptions 
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ESInvocationException is a base class for all the exceptions that can be 
thrown by the Core back to the Client occurring during the processing of the 
request. Exceptions thrown by most handlers are included here to reduce the 
number of explicit classes of exceptions that must be caught. This exception is 
further subclassed into: 

NamingException results from a wide variety of problems. Regardless of the 
cause, this exception, or any of its subclasses, is thrown only for the primary 
Resource of the message header. Five subclasses are defined: 

• NameNot FoundExcept ion is thrown when the name resolution process failed 
to find a given name. The Client can recover by changing ESName. 

• EmptyMappingExcept ion is throvra when a Mapping Object is associated 
with the name, but that Mapping Object has no usable accessors. This condition 
arises when the accessor has no elements, the elements refer to unregistered 
Resources, or the Resources did not pass the visibility tests. The Client can 
recover by changing ESName or trying again with a different set of Keys. 

• UnresolvedBindingExcept ion is thrown when all the accessors of the 
Mapping Object are search requests. The CUent can recover by requesting a 
lookup using the search request. 

• MultipleResolvedBindingException is thrown when the Mapping 
Object has more than one explicit binding. 

• LoopDetectedException is currently unused. 

StaleEntryException is thrown if the Resource no longer exists. The Core 
removes any stale handles from the Mapping Object before returning the exception. 
A retry does not result in this exception unless another referenced Resource has 
been unregistered. 

PermissionDeniedException is thrown by any Resource Handler when the 
client is not authorized to access the Resource. The Client can recover by retrying 
with a diff'erent set of certificates. One subclass is defined 

• SessionRequiredException is thrown when a client attempts to send it a 
message without first setting up a session. The service has security enabled and 
is performing access control checks. A secure session is needed so that the 
access control check can be made. This would normally be handled by the client 
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Ubrary and is transparent to the application programmer. The client recovers 
from this exception by exchanging SLS messages with the service to establish a 
session. 

Quot aExhaustedExcept ion is thrown when the Client attempts to define more 
Resources than it is allowed as defined by the quota assigned. The Client can delete 
other Resources (thus fi-eeing up quota) and reattempt the request. 

MethodNotlmplementedException is thrown when the Client attempts to 
invoke a method on a Resource that is not implemented even though the method is 
consistent with the type of the Resource. This is typically used to "stub-out** 
routines when a service is under development. 

RecoverableCoreException is thrown when there is a problem while 
processing the request. There are two associated subclass exceptions: 

• RequestNotDeliveredException is thrown when the Core never started 
processing the message. This exception can be thrown by the Client library if it 
implements time-outs or in by the Core if the corresponding queue is full It may 
be possible to recover from this exception by resending the message. 

• Part ialStateUpdateExcept ion is thrown when the Core cannot finish 
processing the message. The Client may need to find out what state was changed 
before attempting recovery, for example, by examining the state of the 
metadata. 

Timedout Exc ep t i on is thrown when a message being written to or received from 
a channel has not successfully completed within the caller defined time period, 

UndeliverableRequestException is thrown when the message cannot be 
delivered to the Resource Handler. In the current implementation, this is not 
thrown with security enabled, the security subsystem silently ignores such 
messages (in case diey are a denial of service attack) and the Client has to wait for 
a TimeOutException There are two subclass exceptions of 
UndeliverableRequestException: 

• RecoverableDeliveryExcept ion is due to temporary conditions such as a 
full Mailbox. Recovery can be as simple as retrying. 
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• UnrecoverableDeliveryExcept ion is due to a condition that is unlikely to 
change quickly. The Client can recover by selecting a binding that points to a 
different Resource Handler. 

ESServiceException is a base class exception for all service-defined 
exceptions. 

• ESNameFrameException is the super class of aU name frame exceptions.This 
allows the client to catch this exception and handle all the name frame related 
exceptions in one catch block. 

• NameCollisionException is thrown when the name specified in an 
add, copy, or similar operation is already defined in the Name Frame. 

• LookupFailedException is thrown when no Resources are found that 
match a Search Recipe. 

• invalidNameException is thrown when a string designating a name is 
not found in the Name Frame. 

• ESRemoteException is thrown if the Remote Resource Manager operation 
failed for any reason, details are in the exception state. 



Exception State 

Each exception has the following state. 

class ESException { 
int errno; 
Object [] info; 
} 

The field errno indicates the type of the exception as shown below. 

NONE- 0 

ESRuntimeExceptions (1-99 reserved) 
INVALID_PARAMETER= 1 
NUIiL_PARAMETER= 2 
INVALID_VALUE= 3 
INVALID_TYPE= 4 
0UT_0F_0RDER_REQUEST= 5 
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CORE_PANIC= 6 
SERVICE_PANIC= 7 
REPOSITORY_FULL=: 8 

ESExceptions (100-999 reserved) 
INVOCATION^ 100 
NAMING- 101 
NAME_NOT_FOUND= 102 
EMPTY_MAPPING= 103 
UNRESOLVED_BINDING= 104 
iynJLTIPLE_RESOLVED__BINDING= 105 
PERMISSION_DENIED = 106 
QUOTA_EXHAUSTED= 107 
STALE_ENTRY_ACCESS= 108 
RECOVERABLE_CORE= 109 
PARTIAL_STATE_UPDATE= 110 
REQUEST_NOT_DELIVERED= 111 
UNDELIVERABLE__REQUEST= 112 
UNRECOVERABLE_DELIVERY= 113 
RECOVERABLE_DELIVERY= 114 
TIMED_OUT= 115 
METHOD__NOT_IMPLEMENTED= 116 
LOOP_DETECTED= 117 
SESSION_REQUXRED= 118 
CONNECTIONFAILED= 119 

E-speak defined service exceptions 

SERVICE= 200 



Name frame service exceptions 

NAMEFRAME= 201 
INVALID_NAME=: 2 02 
NAME_COLLISION= 203 
LOOKUP FAILED= 204 



Import/Export service exceptions 

REMOTE= 210 

Client Library defined exceptions 

ESLIB = 950 
CORE_NOT_FOUND= 951 

Exception numbers 1000+ are reserved for application use 
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Exception hierarchy 

Here is the exception hierarchy. Indentation indicates position in the hierarchy. 

ESRuntime Except ion 

ServicePanicException 

OutofOrderRequestException 

CorePanicException 

ConnectionFailedException 

Repository FullExcept ion 

ConnectionFailedException 

InvalidParameterException 

InvalidTypeException 

InvalidValueException 

Nu 1 1 Par ame t e r Exc ep t i on 
ESException 

ESLibException 

Cor eNo t FoundExc ep t i on 
ESServiceException 

ESRemote Except ion 

ESNameFrameExcep t ion 

NameCollisionException 

Inval idNameExcep t ion 

LookupFailedException 
ESInvocationException 

StaleEntryAccessException 

PermissionDeniedException 

S e s s i onRegui r edExcep t ion 

QuotaExhaustedException 

MethodNot Implement edException 

RecoverableCoreException 

PartialStateUpdateException 

Reques tNot De 1 i veredExcept ion 

NamingExc ep t i on 

MultipleResolvedBindingException 

UnresolvedBindingException 

NameNotFoundException 

LoopDetectedException 

EmptyMappingException 

TimedOutException 

Unde 1 iverabl eReque s t Exc ep t ion 

RecoverableDeliveryException 

UnrecoverableDe 1 i veryExcept ion 
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Chapter 8 Core Generated Events & Event 

Distributor Vocabularies 



The e-speak event service is described in the E-speak Programmer's Guide. The 
Core itself is an example of an Event Publisher. It sends Events to an external Client 
called the Core Distributorlo signal state changes such as a change in a Resource's 
attributes. The Core Distributor can then distribute these Events to interested 
Clients that have appropriate authority. 



Events 

An e-speak Event is a set of named attributes, where each attribute is a name-value 
pair. An Event also contains a reference to an e-speak Vocabulary. The Vocabulary 
enumerates the names of sdlowed attributes and their types. Specifying a 
Vocabulary in an Event makes the Event content self-describing. A recipient of a 
self-describing Event does not need to know anything about the Event's content a 
priort, it can query the Vocabulary to determine the Event's attributes and their 
types and then extract the values of the attributes it is interested in. Event 
generators can choose to leave the vocabulary field null, in which case Event 
attributes must be agreed upon a priori, the default meaning being the e-speak Base 
Vocabulary. 

An Event is defined as follows: 
class Event 

{ 

String eventType; 
EventAttributeSet eventAttrs; 
EventAt tribute Set controlAttrs ; 
Object pay load; 

} 
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Every event has a string that describes the event type and two AttributeSets (sets of 
name-value pairs). The first AttributeSet is the attributes that describe the event. 
The second AttributeSet are control attributes that intermediating entities (such as 
distributors) can insert into the event. Matching (filtering) can only be performed 
on the event attributes, not on the control attributes. A string is valid for eventType, 
the meaning of the string is application dependent. 

EventAttributeSet contains an AttributeSet (xref to chapter on 
resourceDescriptions, section on Resource Description defines AttributeSet): 

class EventAttributeSet extends AttributeSet 

AttributeSet attrs; 
String format; 

} 

The string format indicates the format of each Attribute in the AttributeSet attrs. 
" VOCAB" means that the attributes have to be valid in the vocabulary references in 
the AttributeSet attrs. "SIMPLE" means the attributes are simple (name, value) pairs 
and no valid vocabulary is specified in attrs. 



Core Generated Events 

The Core is a Publisher of Events. All Events published by the Core go to a single 
service called the Core Distributor Service. This service is the Resource Handler 
for several Distributor Resources, each dealing with a Core-generated Event of a 
different type. These are: 

• Changes to the state of the Repository 

• Changes to the state of Core-managed Resources 

These types are used to maintain the coherence of metadata and the Resource state 
shared by value. Both are described in the Base Event Vocabulary, 

The string in the eventType field for events generated by the e-speak Core consists 
of a prefix indicating the component that generated the event, followed by further 
information (such as the name of the method being invoked). 
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Core Generated Events 



The eventAttrs field consists of a set of name, string-value pairs. Two common 
examples are: 

• name " Name" , value is the stringified version of the ESUID of the Resource 
responsible for generating the event 

• name "FailureDetaiF , value is a string indicating the nature of the failure 
The format string of the EventAttributeSet eventAttrs is "SIMPLE". 

The payload field is null for events generated by the e-speak Core, 

The following is the list of prefix strings used by the current implementation. 

" core . mutate . Name Frame Interface . " 

"core .mutate . MailBoxInterf ace . " 

" core . mutate . Protect ionDomainlnterf ace . " 

"core .mutate .RepositoryViewInterf ace . " 

" core . mutate . Vocabularylnterf ace . " 

"core .mutate .VocabularyToolBoxInterf ace . " 

" core . mutate . ResourceFact oryint erf ace . " 

" core . mutate . ResourceManipulat ionlnterf ace . " 

" core . mutate . ImporterExporterlnterf ace . " 

" core . mutate . SecureBoot . " 

"core . failure . " 

" core . failure . exception . " 

"notifySync " 

"notify" 

"publish" 

"subscribe" 

"unpublish" 

"unsubscribe" 

"net . espeak . services , events . intf . ESListenerInt f " 

"net . espeak . services , events . intf . Distributorlntf " 

"net . espeak . j esi . event . coredist . ESCoreDistributorInt f " 

"net . espeak . infra . cci . events . Event " 

"service . create" 

" service .delete " 

" service . mutate " 

" service . access " 

" service . pause " 

" service . resume " 

" servi ce . panic " 

"service. genericlnfo" 

"management . service . create" 

"management . service . coldreset " 
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"management . service .warmreset" 

"management . service . stop" 

"management . service . start " 

"management . seorvice . shutdown" 

"management . service . remove " 

"management . service . error" 

"management . service . info" 

"management . service . illegalstate " 

"management . servicemanager . newservice " 

"management . servicemanager . deleteservice" 

"management . servicemanager . servicechanged" 

"resource . change_state" 

"resource. invalid_st ate" 

"resource . invalid_state_transition" 

" resource . statistics " 

"resource .proxy_created" 

" coremanager . info" 

" coremanager . warning " 

" coremanager . serious " 



Publication of Core-generated Events 

The e-speak core sends events to the core distributor as a Protocol Data Unit 
containing a MessageForResource (xref to ESPDU section in communications 
chapter). The payload field of the MessageForResource is the event. The payioadType 
of MessageForResource is set to EVENT. 

The e-speak Core does not subscribe to the Core Distributor (as an ordinary Client 
would). 
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Distributor Vocabulary 



A vocabulary is defined in which Distributors can be registered. 
Table 1 1 Distributor vocabulary 



Attribute 
Name 


Value Type 


Comment 


ivicaillliu 


Name 


String 


Default value 

"BaseDlstributorVocabuiary" 




Type 


String 






ESGroup 


String 






oui iLF dLLiNiarn 
es 


String 






ServiceName 


String 




iMdiiie dbbigneu to utsiriDUtor 


ServiceType 


String 




Type of distributor 


EventTypes 


String 


Multivalued 


Event types handled 


Persistent 


Booiean 


always false 


True if Distributor state survives Core 
restart 


Buffered 


Boolean 


always false 


True if Distributor is able to accept 
events faster than it can forward 
them 


Secured 


Booiean 


always false 


True if event state is tamper proof 


QOSLevei 


Integer 


always 0 


Quality of service level assigned by 
Distributor 


Multiplexed 


String 


Multivalued 


Type of aggregation and 
summarization 
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The Service Name, Service Type, and Event Types are strings that are assumed to 
have meaning to Publishers and Subscribers who have discovered the Distributor. 
For example, the Core Distributor could be described with a Service Name of 
"Core" , a Service Type of "Core** , and Event Types of "Repository" and Metadata'* . 

The Persistent, Buffered, Secure, and QOSLevel attributes must be set as shown 
because the current Distributor implementation does not support these features. 
The Multiplexed attribute can be set by Distributors to describe how they combine 
events. For example, a Distributor can aggregate billing events from a particular 
customer and publish an aggregate event to the subscribers. The values assigned 
are assumed to have meaning to the Publishers and Subscribers of the events. 



Events in a Distributed Environment (Informational) 

Events are messages that trigger special actions by the recipients. In particular, 
when a Client receives an Event, the callback registered for this Event is invoked. 
It would be inappropriate for the Remote Resource Handler to invoke the callback. 
In fact, the Remote Resource Handler has no idea what to do with the Event. As 
currently implemented, no special action is needed. The result is delivery of the 
Event to the Client with no special action on the part of the Remote Resource 
Handler. 

The state of Resources exported by value and the metadata of all exported 
Resources is not synchronized by default Clients wishing to synchronize exported 
or imported Resources register for the Core-generated metadata and Resource 
Events. They also subscribe to the Resource Event if the Core-managed Resource 
is being exported by value. 

Care is needed to avoid cycles. Consider an exported Resource that has its 
metadata changed on the importing side. Assume that a Client on each Logical 
Machine has subscribed to metadata Events for this Resource with Core 
Distributors from both Logical Machines. When one Client makes a change, they 
both get the Event. 
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Even if the Client making the change doesn't respond to the change Event, the other 
Client must make the change on its Logical Machine. This change can generate an 
Event that reaches the first Client. Not having any knowledge of the source of the 
Event, the Client makes the change again. These two Clients continue repeating the 
same change forever except for the fact that the Core generates a Resource or 
metadata Event only if the state is actually changed. Hence, the second change on 
each side does not generate an Event, and the cycle is broken. 

Other cycles can occur. Two Clients that make changes to the metadata while the 
Events are propagating can generate a cycle that is not broken so simply. The 
problem is that they are both changing the same item without synchronizing. Such 
conditions are almost certainly programming errors. No action taken by any e- 
speakcomponent can be guaranteed to break such cycles. Only the Clients have 
sufficient information to detect the problem. 
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Chapter 9 Management 



Two concepts underpin the manageability of e-speak Resources and Clients. 

• Managed State: a defined service state embodying the life cycle of a service. 

• Managed Variable Table: sets of values that can be affected by a manager for the 
purposes of configuration and control. 

Managed Life Cycle 

The full state transition diagram is as follows. 
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State Descriptions 

Initializing 

The internal dynamic state of the service is being constructed, for example: a policy 
manager is being queried for configuration information and resources are being 
discovered via search recipes or yellow pages servers. When the service finishes 
this work it moves asynchronously into the ready or error states. 

Ready 

The service is in a ready to run situation, this state is also equivalent to a stopped or 
paused state. 



192 



Developer Release X.03.03.00, September 2000 



Management 



Managed Life Cycle 



Running 

The service is running and responding to methods invoked on its operational 
interfaces. If an error occurs which implies that the service cannot continue to run 
it should move into the error state. 

Error 

The service has some problem and is awaiting management action on what to do 
next. 

Closed 

The service has removed/deleted much of its internal state and awaits either a 
coldReset or remove transitions. 

Inputs 

An input is the trigger that causes a state transition to occur. In any given state there 
is a defined set of permissible inputs that are available, i.e. only those that are 
depicted in the diagram as leaving the current state and connecting with the next 
state. To attempt to perform any other transition is illegal Note thM many inputs 
can have the same name (e.g. error) yet there is no ambiguity as long as the 
originating state is different. 

Clients can provide any input with impunity However a management agent can 
request only provide external inputs. For example the manager might reasonably 
request that a client perform a warm reset, but not to become ready, the client alone 
can provide this input i.e. when it's internal initialization process has completed. 

The available inputs are as follows. 

• start: move into the running state. Start to handle invocations on operational 
interfaces. 

• stop: move into the ready state. Stop handling invocations on operational 
interfaces. 

• ready: move into the ready state having finished initialization. 
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• error: move into the error state, this transition is valid from any state. 

• shutdown: clean up any internal state required and move into the closed state. 
This transition should not cause the deregistering of resources from the 
repository. 

• coldReset: cause a from complete reinitialization of the service and move into 
the initializing state. The only exemption is that resources that are already 
registered should not be reregistered. 

• warmReset: cause a partial reinitialization of the service i.e. retaining some of 
the existing service state move into the initializing state. 

• remove: cause the service to remove itself from existence. Any non-persistent 
resources should be deregistered from the repository. 



Managed Variable Tables 

A managed variable table is at it's simplest a table of name/string value pairs that 
exist within the client but to which a manager has some level of access. Thus a 
management agent can control those aspects of a services behavior that is affected 
by those variables to which it has access. 

There is a degree of configurability associated with managed variables and their 
variables that permit something more sophisticated than the simple get and set 
operations one would expect to find. 

Each table itself has a name to distinguish it from other tables. As we shall see later, 
the managed service model itself provides for two such tables. 

There is a restriction on variable table usage: each name in a variable table must be 
unique within that table. It is not possible to implement lists by having many entries 
with the same name. 
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Configuration Parameter Table 



The configuration parameter table is an instance of a managed variable table with a 
reserved name that identifies it as such. The table holds generic configuration data 
for the client. 



The resource table is another instance of a managed variable table, identical in 
behavior to the configuration parameter table except that the names in the client's 
table refer to other services with which the client has some relationship. For 
example, if a particular client makes use of a mail service then this relationship can 
be made visible to a management agent through the resource table. Thus a 
management agent might reconfigure the client to use an alternative but equivalent 
service. While there might seem no obvious need to separate out this particular 
aspect of configuration, doing so makes it possible for a management agent to 
discover the topology and integrity of a network of connected services without the 
need for service specific interpretation of the variable table (all entries in the 
resource table are resources). 

The name used for an entry in a resource table can be any symbolic name the client 
chooses, while the value must be the valid e-speak ESName of the actual service. 



All e-speak Resources that are manageable implement the ManagedService 
interface. This applies whether the Resources are external to the e-speak Core, or 
Core-managed. 

interface ManagedServicelntf { 

String getName ( ) 

throws ESInvocationException; 

String getDescription ( ) 
throws ESInvocationException; 

String getOwner() 



Resource Table 



Managed 



Service Interface 
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throws ESInvocationException; 

String getUptimeO 

throws ESInvocationException; 

String getVersionO 

throws ESInvocationException; 

String getErrorConditionO 
throws ESInvocationException; 

String getstaticinf o () 
throws ESInvocationException; 

void coldResetO 

throws I llegal S t at eTr ans i t ion , ES Invocat ionExcep t ion ; 
void warmReset ( ) 

throws IllegalStateTransition, ESInvocationException; 
void start ( ) 

throws IllegalStateTransition, ESInvocationException; 
void stopO 

throws IllegalStateTransition, ESInvocationException; 
void shutdown 0 

throws IllegalStateTransition, ESInvocationException; 
void remove ( ) 

throws IllegalStateTransition, ESInvocationException; 
int getStateO 

throws ESInvocationException; 

VariableEntry [] getVariableEntries ( ) 
throws ESInvocationException; 

String [] getVariableNames ( ) 
throws ESInvocationException; 

VariableEntry getVariableEntry (String name) 
throws ESInvocationException, NoSuchVariableName ; 

void setVariable (String name. String value) 
throws ESInvocationException; 
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ResourceEntry [] getResourceEntries ( ) 
throws ESInvocationException; 

String [] getResourceNames ( ) 
throws ESInvocationException; 

ResourceEntry getResourceEntry (String name) 
throws NoSuchVariableName, ESInvocationException; 

void setResource (String name, ESName resource) 

throws ESInvocationException; 

} 

The method getName return String containing the service name. This name should 
be used when registering the service resource in the service vocabulary. 

The method getDescription returns a human readable description of the service for 
display on a management console. 

The method getOwner returns a string indicating the owner of the service. 

The method getUptime gets the time for which the service has been running. The 
format of the string is "years.days.hours.minutes.seconds". 

The method getVersion returns a string indicating the version of the service. 

The method getErrorCondition returns a string indicating the error condition. This 
returns null if the service is not in an error state. 

The method getStaticInfo returns an XML document of the following form. 

<staticlnf o> 

<name>the name of the resource </name> 

<owner> the name nameof the onwning service < /owner > 

<description> the decription here </description> 

<version> the version string </version> 

<uptime> the uptime string </uptime> 

</staticInf o> 

The coldReset transition function cause the service to move into the initializing 
state and completely reinitialize. The exception IllegalStateTransitionException is 
thrown if the state is not in the ready, error or closed states. 
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The warmReset transition function cause the service to move into the initializing 
state and partially reinitialize. The exception lUegalStateTransitionException is 
thrown if the state is not in the ready or error states. 

The start transition function cause the service to move into the running state and 
service client requests. The lUegalStateTransitionException exception is thrown if 
the state is not in the ready state. 

The stop transition function cause the service to move into the ready state and stop 
serving client requests. The exception lUegalStateTransitionException is thrown if 
the state is not in the running state 

The shutdown transition function clean up any internal state required and move 
into the closed state. This transition should not cause the deregistering of resources 
from the repository. The exception lUegalStateTransitionException is thrown, if the 
state is already in the closed state. 

The remove transition function causes the service to remove itself from existence. 
Any non-persistent resources should be deregistered. The exception 
lUegalStateTransitionException is thrown if the state is not in the closed state. 

The method getState return the current state: an integer value from 0 to 4. 

The value returned is interpreted as foUows. 

• InitiaUzing (0) - the service is constructing its internal data structures and finding 
other services which is needs to function. 

• Ready (1) - the service is fully constructed and ready to run. 

• Running (2) - the service is running and handling methods on its operational 
interfaces, 

• Closed (3) - the service has deleted much of its internal state and closed any open 
connections to flies or other services. 

• Error(4) - The service has encountered an error preventing the service from 
continuing to operate. 
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The Variable Table 

Each manageable Resource maintains a table of name value pairs, which contains 
whatever information that Resource wishes to expose to the management agent. 
The table entries can be either read only or read write. 

class VariableEntry { 

String name; 

String value; 

int updateType; 

} 

The method getVariableEntries returns the table as an array of VariableEntry 's. 
Each VariableEntry object contains the name, the value & update information. 

The method getVariableNames returns an array of strings - one element in the array 
for each variable. 

The method getVariableEntry returns the entry in the table for variable identified in 
the parameter name. 

The method setVariable sets the variable identified by the parameter name to the 
string in the value parameter. 

The Resource Table 

The managed Resource maintains a table of name-Resource pairs. This table 
contains all the Resources that the element depends on i.e. uses. The table entries 
can be either read only or read write. 

class ResourceEntry { 
String name; 
ESName resource; 
int updateType; 
} 

The method getResourceEntries returns the table as an array of ResourceEntry. 
Each entry contains a string that name for the resource, the ESName of the resource 
(URL) and the update information. 

The method getResourceNames returns an array of strings, one element for each 
entry in the resource table. 



Developer Release X.03.03.00, September 2000 



199 



Managed Service Interface 



Management 



The method getResourceEntry (String name) returns the entry in the table for the 
named resource. 

The method setResource sets the Resource identified by the name parameter to the 
ESName supplied in the resource parameter. 
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Chapter 1 0 Repository (Informational) 



The Repository is not part of the e-speak architecture because Clients have no 
direct interaction with it. However, understanding the operation of the Repository 
helps in understanding other parts of the architecture. Also, the behavior of the 
system depends on how the Repository is configured. This chapter describes the 
reference implementation, the Core-Repository interfaces for including 
Repositories of different internal structures, and various scalability issues. 



Repository Overview 

The Repository holds the data needed by the Core, This data includes the Resource 
metadata as well as the internal state of Core-managed Resources. The Repository 
is also read by the Lookup Service when a Client requests a lookup. These two 
operations have different design points. Access to metadata and Core-managed 
Resources is done frequently and needs to be low latency. Lookup requests are akin 
to database queries; they are less latency sensitive but must be completed relatively 
quickly. 



Repository Structure 

To support the conflicting goals of flexible query lookup on a large persistent set 
and rapid access to a smaller, transient subset, the reference implementation of the 
Repository described here is divided into two components: the Repository 
Database and the Repository Access Table. 
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The Repository Database provides persistent storage and efficient lookup request 
processing. This component is left parameterized in the Core-Repository interface. 
All that is needed is an appropriate database interface. This design allows different 
implementations of the Repository to select the most appropriate database based 
on relevant business and technical considerations. 

A very broad range of persistent repository implementation is allowed. This 
Repository Database interface gives another architectural degree of freedom. For 
instance, in the case of a battery-backed RAM device or in situations where 
persistence is simply not a requirement, a pure RAM-based Repository Database 
implementation is feasible. Thus, the Repository Database need not have a large 
footprint. 

The second component the Repository Access Table, is fully resident in memory in 
the reference implementation. This access table is rebuilt from data in the 
Repository Database as part of a system restart. The access table supports a fast 
associative lookup of information based on Repository Handles. It can be a cache 
of the Repository data, or it might be large enough to hold all the data needed for 
Resource access. 



Information Flow 

Every e-speak installation comes with an in-memory Repository that does not 
support persistence. To add the feature of scalability, a gluelayer must be provided 
to convert Core requests to the Repository into meaningful requests to the selected 
implementation. This glue layer must implement the information flow methods 
described in this section. In addition, the glue layer can also include interfaces 
specific to the selected Repository implementation, such as setting controls. 

The Repository Database has two interfaces used by the Core. The Core-Repository 
interfaces have methods to: 

• Register and unregister Resources 

• Access the metadata corresponding to a given Repository Handle 

• Modify the metadata corresponding to a given Repository Handle 
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• Look up Resources that match a Search Recipe 

The Client can access these methods only indirectly by invoking methods in the 
Contract, Name Frame, and MetaResource. The following illustrate the methods 
that need to be supported in these interfaces. The exact signatures and functions 
vary from implementation to implementation. In the current implementation these 
interfaces can be found in netespeakinfra.core.repository .Repository 

public RepositoryHandle registerDescription ( 
String name. 
Re s our c eDe s c r ip t i on d , 
ResourceSpecif ication s) 
throws InvalidSpecif icationException^- 
public void unregisterDescription( 
RepositoryHandle handle) 
throws StaleHandleException; 

public ResourceDescription accessDescription ( 
RepositoryHandle handle) 
throws StaleHandleException; 

public ResourceSpecif ication accessSpec ( 
RepositoryHandle handle) 
throws StaleHandleException; 

public RepositoryHandle mutateDescription ( 
RepositoryHandle handle , 

ResourceDescription d, 
ResourceSpecif ication s) 
throws StaleHandleException; 

The second interface is presented to the Core by the Repository to invoke the 
Lookup Service for a Repository lookup request. This interface is invoked when the 
Client does a lookup in a Name Frame: 

public RepositoryHandle!] find (SearchRecipe recipe) 
throws InvalidSearchRequestException; 

The Repository can access permanent storage, but the protocol used for such 
access is not part of thee-speak architecture. 
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Increasing Scalability 

Because a Resource can be used only if it has been registered in the local 
Repository, it is important to consider the eventuality of a full Repository, Two 
kinds of e-speak Repositories are based on deployment needs: a thin Repository 
and a fat Repository. 

A thin Repository does not have enough disk space to grow with the number of 
Repository entries. Its purpose is to support Repository Handle-based access, with 
latency on the order of microseconds. This support is provided on a smaller, 
transient, subset of Repository entries, which corresponds to*' in-use** Resources. A 
thin Repository is very sensitive to stale data; it must enforce strong policies to: 

• Dispose of stale entries, and 

• Prevent marginally accessed entries from accumulating. 

A thin Repository can have no persistent storage of its ovm. Thus, because the 
number of Repository entries that can be stored in a thin Repository is small, an 
in-/77e/730/7 Repository implementation is appropriate. 

A fat Repository has a lot of disk space and can act as a server to a thin Repository. 
Clearly, such a Repository can be highly available. The primary purpose of such a 
Repository is to support Resource lookup requests with "reasonable" latency (on 
the order of milliseconds) . A fat Repository is not very sensitive to stale data. 
Because the number of Repository entries that can be stored in a fat Repository is 
very large, Repository implementation based on a database is appropriate. 

A thin Repository can use a fat Repository to fulfill its scalability needs, and a fat 
Repository can simultaneously serve many thin Repositories. However, many 
devices cannot need such support because their transient state can hold all the 
information necessary. 

The communication between a fat Repository that provides services to a thin 
Repository is not part of the e-speak architecture. However, because the security of 
the system depends on the integrity of this communication, the link must be 
protected. It is the security of the communication link that makes the Repository 
part of the Core, irrespective of the physical machine that holds the Repository. 



204 



Developer Release X.03.03.00, September 2000 



Repository (Informational) 



The keylndexType field: Efficient Repository Lookup 



The keylndexType field: Efficient Repository Lookup 

In DBMS, indexes are the primary means of reducing the volume of data that must 
be fetched and processed in response to a query. If there were no indexes used for 
resource description attributes in an e-speak repository, every resource defined 
against a particular vocabulary needs to be examined to see if it matches the 
constraints specified in the search recipe. This would cause very slow performance 
on lookups when large numbers of resources are registered in the e-speak Core. So 
there needs to be a way of specifying which attributes properties within a 
Vocabulary are the 'key' attributes so that some indexing scheme can be added. 

It is not reasonable to index each and every attribute in a resource description. The 
more indexes that you have, the more overhead in registering descriptions and also 
the memory requirement becomes more for in-memory repository. It does not make 
sense to index attributes that are not going to be frequently used in constraints. 
Therefore, there needs to be a way of specifying which attribute properties within 
a vocabulary are the 'key' attributes so that some indexing scheme can be 
implemented on these 'key' attribute properties. 

This is the purpose of the keylndexType field in AttributeProperty (xref to core 
managed resource Vocabulary section). Valid values of keylndexType are: 
NO JNDEX, HASHJNDEX and TREE JNDEX. If the value is HASH JNDEX or 
TREEJNDEX the attribute is used as an index by the DBMS. 
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A key factor in global acceptance of a software package is its ability to be 
customized to the location running the software. It is very frustrating for a user to 
have to read messages in a language other than their own native language or 
interpret numbers using a foreign format. Imagine if you had to understand an error 
message written in German, or recognized that the string "06/01/99" really means 
January 6th and not June 1st. 

This chapter describes how to support localizing e-speak for native language and 
locale-dependent number & date formats. This design is implemented in the current 
release of e-speak. However, currently all entities have the same underlying data 
catalog to get their localized strings. 



Current Implementation 

The current code has hard-coded strings for all display messages and exception 
details. It also hard-codes the format of number and date/time representations. 
For example: 

• net.espeak.infra.core.startup.StartESCore prints a message when the core is 
initialized using System.out.printC Starting ES Core Server with Rendezvous of 
r + popURL + T. "); and System.out.println(" started.");. 

• ValucgetStringO simply calls the toString method of the data type object 
represented by the Value class. 
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String Messages 

There are three requirements for string messages: 

• A framework implementation which supports the use of localized string 
messages. 

• A English implementation of all string messages within the core, cci and client 
packages, using the framework created above. 

• Additional language implementations as required by our customers. 
Framework 

• Any time the message text is moved away from the code that produces the 
message, confusion and incorrect messaging is likely. It is important, therefore, 
that the framework minimized the confusion and makes it difficult to issue the 
incorrect message. A hierarchical structure must be supported for the 
specification of the message to be issued. 

• Messages are rarely static, i.e., they often contain concatenations of variable 
values in the middle of the message. The framework must support the 
substitution of variable values in the body of the message. 

• The framework must support the specification of the location and language of 
the user. If support for the requested location and language are not 
implemented, the framework should provide the closest match to the requested 
location and language available. 

• A likely scenario includes the core running in one locale and the client running 
in a different locale. The framework must support a core issuing a message in 
the client's locale language. 

• During development phases, the framework should throw exceptions if the 
invocation of the messaging methods are coded incorrectly (e.g., a message id 
that is not valid), but in the release the framework should make a best attempt 
to format the message for the user. 
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• The framework must be initialized during the startup of the e-speak processes. 
English implementation 

1 The current code base must be examined for each string message that is 
produced. Unless there is a good reason for keeping the message definition local 
(e.g., a debug message), the text of the message should be placed in the English 
string implementation file and the reference changed to retrieve the message 
text. 

2 This English implementation becomes the base implementation and is shown to 
the user as the default language if their specified language is not implemented. 

Additional language implementations 

• After a good English implementation has been developed additional language 
implementations can be created translating the message text from English to the 
new language. 

• After an additional language is created, changes to existing messages must also 
be changed in each of the additional languages. This is a development process 
issue that is addressed further here. 

• If a new message is created in the base implementation (English) , the new 
message does not need to be implemented in all other languages, however, if this 
is the case the user sees the English version of the message. 



Number & Date Formats 



The requirements for non-string formats is broken into two categories: 

• Vocabulary attributes 

• Value class string representations 



Developer Release X.03.03.00, September 2000 



209 



High-level Design 



Localization 



Vocabulary Attributes 

Three new data types should be supported which provide for locale-defined 
formats. They are: 

• Decimal: This data type provides for a decimal representation of a number in a 
user-defined pattern. The pattern can be derived from the locale-defined format 
or customized by the user. For example: Decimal number = new 
DecimalC###,###.#r); 

• Currency: This data type provides a specialized Decimal format that includes the 
currency symbol and format defined by the user's locale, 

• Per: This data type provides a specialized Decimal format for percentages using 
the symbols and format defined by the user s locale. 

Value class string representations 

The Value class getString method should return a string representation that is 
customized by the user's locale formats. Specifically: 

Timestamp Date 

Time Decimal 

Currency Percent 
Numeric data type (Long. Double, Float, etc.) 



High-level Design 

The implementation for the Number and Date formats are left to the Vocabulary 
team. This document only addresses the String Message requirements. Shown 
below is the class diagram for the classes implementing localization. 
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ESSlring 

tnessageID:Stiing 

infoiObiectn ^ 

ESStiingO 

ESString(Stdng) 

ESStiing; Stiing, Object) 

ESStimg(Stdng,mt) 

ESStdng(Stms, Object, Object) 

ESStnng(Stm& ObjectQ) 

toStiing()*Stfing 

receiveObject(MessageInputStreain):Object 
sendObject( MessageOutputStr eam):void 



ESStriitgs 

table:ESMap 

c ontents rObj e ctfl fl 

getKey s() :Enumeration 
handleGetObjec1( Stdng):Object 



ESText 

myResources:ResoiwrceBimdle 
myCustoniResotircesiESIist 

thrQwExceptLonsiboolean 

imlialize( String) :void 
thf 0 wExc eptions( ) :b oole an 
setThrowExceptions( boolean):void 
getLocaleString( Object);String 
getMe s s ageC String) :Stiing 
getMessage( String Object):Stdng 
getMessageC String, Object, Object):Stdng 
getMessage(Stmg 0bject[D5tring 
fmdMessage( Stmg):3tnng 
isDigit( Stiin^:boolean 



ESText, ESStrings & ESString classes 

Three new classes are defined. ESText is the retrieval class and ESStrings is the 
language dependent implementation class. ESString is a logical extension to String 
which performs the locaUzation at the last possible moment (client in most cases). 

The unitize 0 method needs to be called by each process that uses the ESText 
facility. If this method is not called, the first invocation of getMessage defaults to 
the e-speak base class. The unitize method uses the java.utilResourceBundle class 
to discover the language defmed strings. ESText supports multiple base classes. 
After it is unitized, it can be called multiple times with different base class name 
parameters. When ESText looks up a message, it searches all the supplied base 
classes to resolve the message ID. 

The throwExceptions and setThrowException methods return and specify if 
exceptions are thrown for detected problems (see below). 



Developer Release X.03.03.00, September 2000 



211 



High-level Design 



Localization 



Additional getMessage prototypes can be created with multiple params if the need 
arises. 

The base implementation for ESStrings looks like the following: 
public class ESStrings extends ListResourceBundle 

{ 

public Object [][] getContents ( ) { 
return contents; 

} 

static final Object [] [] contents = { 

{ "net .espeak. startup. Hello" , template for IDI"}, 
{"net .espeak.eslib.ESFolder.dup" , ''template for ID2"} 

} 

Each additional language looks like the following: 

pxiblic class ESStrings_de extends ListResourceBundle 

public Object [] [] getContents () { 
return contents; 

} 

static final Object [] [] contents = { 
{ ''net . espeak . startup . Hello" , 
'^German override for IDI"}, 
{ "net . espeak . eslib . ESFolder . dup" , 
''German override for ID2"} 

}; 

} 

Class names are searched in the following order: 

1 baseclass + + language + + country -f + variant 

2 baseclass + + language + " J + country 

3 baseclass + + language 

4 baseclass 

ResourceBundle automatically defers to this search order for any message ID that 
is not foimd in the specific language implementation or if the specific language 
implementation is missing. 

The optional param values are substituted in the message text by the following 
rules: 
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• For each occurrence of the string ""foxf , the string is replaced by the 
object [nJ.toStringO value. Note that this is a zero-based index. 

• If " n" is out of bounds for the supplied params, the string " n/a" should be 
substituted. Note: during development, this situation threw an exception, 

• If a param is not referenced by the message, the param should be ignored. Note: 
during development this situation is thrown an exception. 

• Multiple references to the same param should be valid (e.g., **%0 blah %0") . 

• If the included object is a localizable object (Timestamp, Date, Time or Number) 
the locale-defined formatting rules are applied to this object. 

• To code a percent sign in the message, code two percent signs (%%). 

• To include all passed parameters, code '%air in the message template. This is be 
replaced by [argO, argl, ...]. 

The last class is ESString. This class logically extends the java.lang.String class for 
localization. It accepts a message ID and optional data objects in the same way as 
ESText does. The toString method localizes the message when it is called rather 
than when it is constructed. 



Usage example 

Below is an example of how the StartESCore message can be coded. The 
ESStrings Java class contains the following: 

public class ESStrings extends ListResourceBundle 

public Object [] [] getContents () { 
^ return contents; 

static final Object [] [] contents = { 
{ "es . core . startup . Hellol" , 
^'Starting ES Core Server with " + 
"Rendezvous of \" %0\" . . . " } , 
{''es.core.startup.Hello2", started."} 



The StartESCore Java class contains the following: 
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System . out . print (ESText . getMessage ( 

"es.core.startup.Hellol", popURL) ) ; 
System. out .println (ESText .getMessage ( 

"es. core. startup. Hello2") ) ; 

The ESString class is used as follows: 

throw new StaleEntryAccessException ( 

new ESS t ring O'es. core. star tup. Hel lo2 ) ; 

Additional design considerations 
ID specifications 

To simplify the JD generation and reduce the chances of duplications, the IDs 
should follow the following convention: 

• Use the dot format to specify the hierarchy. For example, message IDs for the 
StartESCore class should be "es.core.startup.StartESCore.*". 

• The last node should be a short description string denoting the message. For 
example, the startup message issued today by StartESCore would have the ID of 
"es,core.starStartESCore,Hello". 

• Messages are defined in the ESStrings class in sorted ID order. 
Core generated exceptions 

Because it is possible that the core is running in a different locale from the client, 
any message text produced in the core that is destined for a client should be 
specified in the client language. To do this, modify the exception classes to pass the 
additional objects instead of the text. The exception.getMessage code on the cUent 
side uses the ESText class to map the exception number to a message ID and 
performs the substitutions in the client *s language. 

Client usage 

Client applications can use these classes as well. They need only call 
ESText.initializeO with the base class name for their ESStrings equivalent. 
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class ESString{ 
String message ID ; 
Object [] info; 



The message ID specifies the text of the message in either the service-defined 
message catalog or the e-speak defined catalog. The message ID is used to retrieve 
a message template from the catalog QESStrings) . The optional Objects are 
substituted into the message based upon the syntax of the message template. 

Message templates can contain the "%" (percent sign) symbol followed by a number. 
The number the index info object The percent sign (and the number following it) 
are substituted with the toString value of the associated object. 

An example entry from the current e-speak message catalog 
(netespeakutiLESStrings) 

MessagelD : "net . espeak . exception . 4 " 

Message template: "Parameter 'tO' invalid type, expected 
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Chapter 1 2 Future Developments 



The next release of e-speak will integrate the current e-speak Core with the Web 
Access architecture (see e-speak Web Access Architecture). It will also implement 
the localization architecture described in Chapter 11, "Localization". 
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This chapter needs check to make sure we are not using terms no longer needed. 
Terms to do with security (keys and locks) need to be removed. New terms need to 
be added: certificate, key, PKI, ACI, Principal, URL, ESPDU probably others. 



Term 



Meaning 



Advertising Service A service for looking up resources not registered in the local 
Repository, It returns zero or more Connection Objects. 



Arbitration policy 



A specification within the search request accessor for naming 
that provides the logic to resolve multiple matches found for 
a name search. 



Attribute 
Vocabulary 



See Vocabulary. 



Base Vocabulary A Vocabulary provided at system start-up. 



Builder 



An entity identified by a Remote Resource Handler that is 
used to construct the internal state of a Resource imported 
by value. 



Certificate 



A data structure assigning a Tag or name to a Subject. 
Certificates are signed using cryptographic techniques so 
they cannot be tampered with. 
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Certificate Issuer 
(CD) 



A service Issuing certificates to Subjects. 



Client 



Any active entity (e.g., a process, thread, service provider) 
that uses the e-speak infrastructure to process a request for 
a Resource. 



Client library The interface specification that defines the interface for 

e-speak programmers and system developers that will build 
e-speak-enabled applications. 



Connection 
Manager 



A Logical Machine's component that does the initial 
connection with another Logical Machine. 



Contract 
Core 



See Resource Contract. 

The active entity of a Logical Machine that mediates access 
to Resources registered in the local Repository. 



Core Event 
Distributor 



A Core-managed Resource whose purpose is to collect 
information on e-speak Events and make such information 
available to management tools within the infrastructures. 



Core-managed 
Resource 



A Resource with an internal state managed by the Core. 



Distributor Service A service that forwards published Events to subscribers. 



Event 



A message that results in the recipient invoking a registered 
callback. 
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Meaning 



Event filter 



A subscription specification expressed as a set of attributes 
in a particular Vocabulary that must match those in the Event 
state in order for a Client to receive notification on publication 
of an Event. 



Event state 



A reference W\lhm an Event to its expressed set of attributes 
in a particular Vocabulary. These attributes must match the 
Event filter in order for the subscriber to receive notification 
of the Event. 



Explicit Binding 



An accessor that contains a Repository Handle. 



Import Name 
Frame 



A container that holds a name for each imported Resource. 



Inbox 



A Core-managed Resource used to hold request messages 
from the Core to a Client. 



Issuer 



An entity issuing a certificate. The Issuer is denoted in a 
certificate by its Public Key 



Logical Machine 
Lookup request 



A Core and its Repository. 

Resources with attributes matching the lookup request will 
be bound to a name in the Client's name space. 



Lookup Service 



The component that performs lookup requests used to find 
Resources that match attribute-value pairs in the Resource 
Description of Resources registered in the Repository, 



Mailbox 



Either an Outbox or an Inbox. 
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Meaning 



Mapping Object 



An object binding an ESName to Resources or a Search 
Recipe. 



Message 



Means of Client-Core communication. 



Metadata 



Data that is not part of the Resource's implementation, but is 
used to describe and protect the Resource. 



Name Frame A Core-managed Resource that associates a string with a 

Mapping Object. 

Name Search A name conflict resolution tool used by the Core to find the 

Policy appropriate strings when looking up names in a Name Frame. 



Outbox 



The location where the Client places a message to request 
access to a Resource. 



Pass-by value A metadata field, which, when set to true, includes the state 

of the Resource in the Export Form. 



Principal 



The entity holding the Private Key corresponding to a given 
Public Key 



Private Key 



This is secret data. An entity demonstrates knowledge of this 
secrete data by cryptographic techniques to authenticate 
itself. Private Keys must be kept secret 



Private Security A cryptographicaiiy secure store for Private Keys. 
Environment (PSE) 
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Meaning 



Protection Domain 



The environment associated with a particular Outbox from 
which Resources can be accessed. 



Publish 
Public Key 



Public Key 
Infrastructure (PKI) 



Repository 
Repository entry 

Repository Handle 
Repository View 



A request sent to the Distributor Service to publish Events. 

Non-secret data that is associated with a given Private Key by 
cryptographic techniques 

A set of services and protocols that support the use of public 
and private key pairs by applications for security. 

A passive entity in the Core that stores Resource metadata 
and the internal state of Core-managed Resources. 

The metadata of a Resource as stored in the Repository and 
made available to the Core when a Client's requests to 
access Resources are processed. 

An index into the Repository associated with the metadata of 
a Resource. 

A Resource that can be used to limit the search for particular 
Resources in a large Resource Repository, much as a 
database view restricts a search within a database. 



Resource Contract 



A Resource denoting an agreement between the Client and 
the Resource Handler for use of a particular Resource. The 
agreement includes a provision for the Client to use an API 
known to the Resource Handler when making the request for 
the Resource. 
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Term 



Meaning 



Resource 



Resource 
Description 



Resource Factory 



Resource Handler 



Resource Specific 
Data 

Resource 
Specification 

Session Layer 
Security Protocol 
(SLS) 

Service Identity 
(Service ID) 

Simple Public Key 

Infrastructure 

(SPKI) 

State 



The fundamental abstraction in e-speak. Consists of state and 
metadata. 

The data specified for the Attribute field of the metadata as 
represented by the Client to the Core. See also Resource 
Specification. 

An entity that can build the internal state of a Resource 
requested by a Client. 

A Client responsible for responding to requests for access to 
one or more Resources. 

A metadata field of a Resource. Carries information about the 
Resource. Can be public or private to the Resource Handler. 

Consists of all metadata fields, except the Attributes field, as 
represented by the Client to the Core. 

The low level message protocol used by all e-speak Cores 
and Clients for remote communication. 



A field in the metadata that identifies a service or Resource 



A specific variant of PKI developed within the Internet 
Engineering Task Force and used by e-speak. 



Data a Resource needs to implement its abstraction. 
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Meaning 



Subject The entity to which the access right or name has been issued. 

In a certificate the Subject is denoted by its Public Key. 

Vocabulary A Resource that contains the set of attributes and value types 

for describing Resources. 

Tag The field in a certificate expressing an access right 

Vocabulary Builder A Core-managed Resource registered by the Lool<up Service 
that is used to create new value types, attributes, and 
Vocabularies. 

Vocabulary A reference to a mechanism that is used to provide 

Translator interoperation between different Vocabularies by mapping 

attributes from one Vocabulary into another through a 

Translator Resource. 
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Appendix B 



The E-Speak Programmer's Guide 
Developer Release 3.03 



Chapter 1 Introduction 



Buying a VCR with E-speak 

Let s suppose we want to buy a new VCR, 

Now, let's look at the differences we would find if we were to try to buy that VCR in 
a large department store and in a large shopping mail. 

The Department store has a known location. It also has known products. 

The products in the department store are generally of the same brand. In addition, 
these products are generally going to have known qualities, such as price, style and 
color. If we were looking for an odd color, we probably wouldn't find it. The price 
is fixed and even though several similar products might be found in slightly different 
price ranges, the ranges are limited. 

These product attributes (price, color and style) are non varying and that is 
extremely helpful for the store in deciding what items to stock. 

Unfortunately for the Client thdX needs to use the store s Service, it may not be 
possible to find the right combination of attributes to meet their requirements. 

Next month, if we need a VCR with a different set of attributes, say a different 
brankd in a different color, and we return to the same location and the store has 
closed, it is a huge inconvenience. Having never anticipated that the store might 
suddenly go 'offline', we are now forced to stop what we are doing and search for 
a new store. 

Now let's go to the mall. 

The first thing we do is to drop by the Directory Board at the entrance to discover 
which stores have advertised their ability to sell VCRs. 
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Armed with this information, we visit each store with our list of required attributes 
for the VCR we want, to see if they can match the price, feature set and style that 
we have in mind. 

Several of these stores may meet our criteria. In that case we can further refine our 
decision making process by prioritizing our request. We may decide to make a list 
with price as the governing item. 

If we return next month with a requirement for a VCR with different attributes, we 
still make our first stop at the Directory Board. If any of the stores that we shopped 
at on the last visit are off line or new ones have been added, it doesn t affect our 
process of buying a VCR. 

After discoveringthe Services that sell VCRs, we make the rounds inquiring about 
the attribute list (color, price, style) that each sell, and since our list of stores is up 
to date, we automatically include new stores that have come on line, and do not 
bother wasting our time making inquires of stores that have closed. 

If a store has changed or reconfigured the attributes of their services, (say they no 
longer offer the VCR in a brand compatable with the rest of our equipment) we will 
find this out during our initial inquiry and they will be filtered out from our final 
decision making process. 

Doing this discovery and inquiry process every time, may seem like an arduous task, 
and indeed it is when we walk around the mall and do it. Fortunately for us, in the 
electronic world, these are the kind of repetitive jobs computers love to do. 

As you have probably guessed by now, E-speak is built along the lines of the 
shopping mall paradigm. 

It s job, like that of a mall, is to connect Services v/ith Clients. 

Services may come and go, so they need to be Dynamically Discoverable and E- 
speak provides for this. 

The attributes (or what a service offers) may change also, so Services need to be 
Dynamically Configurable , and E-speak provides for this too. 
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E-speak does this by supporting a set of characteristics for its Services which allow 
Clients to Discover and use them. 



Service 
Characteristic 


Function 


Description 


Enables a Service to be Discovered 


Interface 


Allows Clients to communicate with Services 


Mediating Access 


Allows Services to coexist with other Services 



Table 1 - Characteristics of E-speak Services 



The way E-speak allows all this dynamic interaction is by separating the different 
roles played by the various members in an E-speak community. 

The entities involved in defining Service ecosystems are categorized as follows 

The roles and Jobs of the members of the E-speak community are: 



Role 


Job 


Service Developers 


Create new Services 


Service Standards Bodies 


Define new services 


Service Deploy ers 


Advertise the services 


Service Directories 


Provide locations where services are advertised 


Service administrators 


Monitor and Control Services 



Table 2 - Roles and Characteristics of E-speak Components 
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Functions and Roles of E-speak Entities 

• Service developers who create new Services 

• Service standards bodies who define new services 

• Service deployers who advertise the services 

• Service Directories which are locations where services are advertise 

• Service administrators who monitor and control services. 

• Service developers: These are the developers of the actual Service 
implementation. Service developers design their Service to comply with the 
programmatic Service interfaces published by the standards bodies. Service 
developers are also able to wrap existing legacy applications so that they can be 
made available as services in the e-speak infrastructure. 

• Service standards bodies: Standardization bodies define and publish 
standardized interfaces for different Service categories that are used by Service 
developers to write Services conforming to the standardized interface. 

For example, a standards body may define a generic printer Service interface to 
contain the following invocation points: print 0. and status 0 Any Service 
provider interested in providing a printer Service writes their Service to support 
this interface. 

In addition, the standardization body is responsible for identifying the Vocabu- 
iaryused to describe a Service. The Vocabulary describes the attributes that are 
used to uniquely describe a Service. For example, a printer Vocabulary includes 
attributes such as Manufacturer, Modelname, DPI and so on (perhaps using 
XML) that is used by service deployers to advertise this Service, and queried by 
Clients to discover it. 

• Service deployers: Service deployers are responsible for deploying the 
Services created by the Service developers. They are responsible for advertising 
the Services in the appropriate Vocabulary and also for handling requests to the 
Service. 

• Service administrators: These administrators are responsible for monitoring, 
administering, and controlling the Service deployment. 
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• Service Directories: These directories are places where service providers and 
clients can advertise and find other services that are of interest to them. 

Segregation of Services 

This segregation of roles allows the Service developers to concentrate on the 
business logic of the Service that they are developing, the Service deployers to 
concentrate on advertising and handling requests to the Service, and the 
administrators to administer the Service. Furthermore, the existence of service 
directories greatly simplifies the process of building new composite services by 
providing a place where services can find other services. An example of such a 
service directory is accessible from the E-speak.hp.com site that each E-speak 
installation points to by default. 

All the above entities get their work done by communication with the e-speak Cora 
The Core is the active entity of e-speak that acts as the mediation layer and routes 
messages to Services. 

Figure 1 shows a typical interaction between Clients and Service providers in an 
e-speak community. 

An e-speak community consists of a number of Cores connected to each other. 
Chents and Service providers join the community through these Cores. 

Clients search for Services registered in the community , and when diey are 
successful, they gain access to the Service using a Service proxy (stub) of the 
discovered Service. 

The Clients need to know only the interface of the Service in order to invoke object- 
oriented functions (methods) on it. 
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Figure 1 Typical interaction between Clients and Service providers 

All access to e-speak go through the E-speak core, unlike other strategies where 
only discovery is done through an infrastructure and conimunications thereafter 
takes place directly between servers and clients. 

The advantages of this are improved: 

• Security mechanisms 

• Accounting 

• Auditing 

• Billing. 
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Programming Model 

The primary goal of E-speak is to simplify the development, deployment, and 
management of communities of Services on the Internet. 

To accomplish this, E-speak provides three basic abstractions: 

• Services 

• Service Contracts 

• Service Vocabularies 

NOTE: All three of these abstractions are Srst class entities in E-Speak 

E-speak Services 

Essentially, Services are programs written in a programming language such as Java, 
C, Perl, and C+-h. 

Figure 2 illustrates the relationship between Services, their Contracts, and their 
Vocabularies. 
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Figure 2 Relationships among Services, Contracts, and Vocabularies 

NOTE: E-speak Services conform to their Contracts because by design, they 
implement the interfaces outlined in their Contract 

All services are advertised in appropriate Vocabularies. 

Service Vocabularies essentially provide the scheme for constructing the 
description of the Service. 

By decoupling Services from the Contract and the Vocabulary, E-speak allows 
Service implementors (the developers) to be independent of Service Deployers (the 
Advertisers). 
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This decoupling is a fundamental part of E-speak. 

NOTE: Clients are not dependent on the Service developer and deployer to 
communicate the Service Contracts and Vocabularies with which these 
Services have been described. 

The mechanism by which this happens proceeds as follows: 

1 The Service Deployers register their Services with a group of E-speak Cores. On 
registering a Service, this Service is discoverable by others in the same E-speak 
group of Cores. 

2 Clients use the default E-speak finders provided or write their own finders to 
find Services that meet their requirements. 

3 The access permissions of the Service determine the Services that will be visible 
to the Clients. 

4 On finding Services, Clients receive a remote stub to the Service, 

Service Contracts 

Each E-speak Service implements a set of interfaces defined in a Service Contract 

Service Contracts are first-class entities that can be discovered and used like any 
other Service. All Service Contracts support a base set of interfaces that provide 
mechanisms to create and query them. 

For this reason, Contracts also can be advertised in a well-known Vocabulary — 
typically by a Standardization Body. 

This ability to standardize Vocabularies into allows finding Services and 
communicating with the to proceed smoothly in E-speak, especially give the highly 
dynamic nature of clients and services on the web. This is the reason E-speak was 
designed the way it was 
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Service Vocabularies 

A Vocabulary consists of a set of associated attributes and properties. The only 
properties associated with any attribute are: 

• Name of the attribute 

• Type of values allowed 

NOTE: The Structure of a Vocabulary is dependent on the vertical market 
for which it is defined. 

For example, the Vocabulary used to define a printer with attributes such as 
manufacturer, model name, DPI, speed, color, and cost is quite different from the 
Vocabulary that defines apparel merchandise that has attributes such as size, color, 
material, and cost. 

Caution: Though some of the attribute names may be the same across Vocabular- 
ies, they may have different semantics. 

The attribute color in the Printer Vocabulary may be a boolean expression that 
indicates whether the printer supports color printing; however, the attribute color 
in the Apparel Vocabulary may indicate the actual color of the piece of clothing. 

Because Vocabularies are first-class entities, Clients and Services alike can find 
these Vocabularies registered in die community and subsequendy make use of 
them. New Vocabularies are typically advertised using the Base Vocabulary that is 
available in the e-speak infrastructure. 

This Base Vocabulary defines a set of attributes that are generic and can be used by 
generic Services in markets that do not have well-defined Vocabularies. All Services 
registered as a Vocabulary conform to the Vocabulary Contract ±at defines the 
operations that can legally be performed on Vocabularies. 

E-speak System Services 

In addition to the base abstractions of Vocabulary, Contracts, and Services, E-Speak 
supports a set of base and extended services that makes the job of deploying and 
using Internet-wide Services simple. 
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Basic Services 

These are the basic set of Services that are required to get connected to the e-speak 
infrastructure and to create and find new user-defined Services. These Services 
include the following: 

• Connection — A connection Service is used to connect and disconnect from the 
e-speak infrastructure. 

• Vocabulary — A Vocabulary Service allows the creation of new Vocabularies 
and queries the properties of existing Vocabularies. 

• Contract — The Contract Service is used to create and use Contracts. 

• Elements and Finders — Service elements are used to register Services with 
the Core, while Service finders are used to find Services. 

Extended Services 

• Events— This Service defines a distributed Event Publisher-Subscriber model 
for Events. Events are distributed by a Distributor across any number of 
connected Cores. 

• Community — This Service enables discovery of Services across multiple 
e-speak cores. Communities are Client-side abstractions of collections of groups 
that form the search domain. The Community is a collection of member core 
groups identified by group names. 

• Folders — The Folder Service allows users to manage their Services (discovered 
or created) similar to how they manage local files in a standard operating 
system. Persistent folders appear on reconnecting and act very much like 
organized hierarchically persistent bookmarks. 

Client-Service Interaction 

As described earlier, Clients find a Service using attributes described in the Service 
Vocabulary. The return value of the f ind ( ) operation is used to further connect to 
the Service 

When Clients discover a Service, they have to specify the interface they want to use. 



Developer Release X.03.03.00, September 2000 



11 



Client - Service Interaction 



Introduction 



The Service provider s abstraction of the Service is a Service element as 
represented by the class ESServiceElement. 

The Service element has, among other things, the description of the Service, the 
description accessor of the Service to mutate the description, and the actual 
implementation of the Service. It also has information about the handler of the 
Service, including the queue on which messages to this Service will be sent and the 
number of threads servicing requests to this Service. 

For example, if a Service provider wants to make an existing, stand-alone 
application (such as PrinterServicelmpl), an e-speak Service, performs the 
following actions: 

1 Define or modify the interface that describes the Service interface. 

2 Create a new ESServiceElement. 

3 The Service deployer provides the description of the Service in a Vocabulary, 
along with the implementation of the Service such as the object 
PrinterServicelmpl to the Service element The element also contains the 
description accessor of the Service that can be used by the deployer to query or 
modify the description of the Service. 

4 After performing these actions, the deployer can use the Service element to start 
the Service. The deployer can also control the concurrence of the Service by 
changing the number of threads that process the requests for diis Service. The 
message queue and threads are controlled by a Service handler. 



Client - Service Interaction 

The following section provides a walkthrough of the interaction between and E- 
Speak Service and a Client that wants to use it. 

First a Service must exist for the Client to be able to find it 
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Service Creation 

A Service provider is primarily interested in implementing a Service interface to 
comply with the Contract and in advertising the Service in an appropriate 
Vocabulary. 

The steps to do this are as follows: 

1 Connect to the e-speak Core. 

2 Create a Service element 

This service element will have a description of any Service Vocabularies and 
Contracts, 

Client Service Discovery 

A Client first creates a new connection to an e-speak Core. After connecting to the 
Core, the Client can look up or register Services. The Client locates a Service that 
satisfies a constraint expressed with attributes in the default Vocabulary, 

The result of the find Service is used to communicate with the Service provider's 
Service as in Figure 3. 
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Service provider 



Figure 3 Client and provider Core relationship 

Client Service Usage 

Clients interact with the Service with the set of interfaces which are available in the 
Client address space. 

NOTE: When a Client invokes an operation, a well-defined e-speak custom 
serialization is used to ship the invocation to the target Service tlirough the 
mediating e-speak infrastructure. 
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Figure 4 shows that the e-speak Core is located between the Client and the Service 
provider. In general, many Cores may lie between the Client's Core and the Core 
where the Service provider is registered. 




Figure 4 The e-speak Core 



Resource Descriptions 

E-speak makes a distinction between the data representing the state of a Resource 
and the data describing the management of the Resource. The Core mediates access 
to any registered Resource. 

NOTE: E-speak is concerned only with the Resource state of Core- 
managed Resources, not with the Resource state of non-Core-managed 
Resources, 
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A Resource is described to E-speak by its metadata. The metadata is composed of 
a Resource Specification and a Resource Description. The Resource Description 
consists of information that provides the means of discovery for Clients. The 
Resource Specification includes: 

• An Inbox that can be connected to the Resource Handler responsible for manag- 
ing the Resource 

• A specification of the security restrictions 

• A variety of control fields 

A Client registers a Resource by sending a message to a Resource Facto/y contain- 
ing a Resource Description and a Resource Specification. 

Together, Resource Descriptions and Resource Specifications include all informa- 
tion the Core needs to enforce the policies specified by the Client registering the 
Resource. If the registration succeeds, the Core returns a name bound to this 
Resource to the Inbox specified by the Callback Resource in the Outbox envelope. 



E-Speak Programming Interfaces 

There are two interface options available with E-speak: 

• Java 

• XML 

JESIi based on Java, allows programmers to interact with the e-speak core or 
services through APIs (Application Programming Interfaces) 

Web Access , based on XML, enables users to interact with the E-speak core or 
services through standard web browsers, by returning HTML or XML documents in 
HTML or XML 
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JESI 

Jesi provides the interface for e-speak to environments that use programmatic 
environments such as Java. 

• In J-ESI, the connection between Clients and the E-speak infrastructure is 
represented by an ESConnection. 

• When a connection is established between a Client and the E-speak Core, 
the capabilities granted to operations performed on this connection 
depend on the credentials that are presented. 

• ESConnection supports APIs that return the Base Vocabulary and 
Contract Services, 

After a connection is established, the Client receives a *stub' that is then used to 
communicate with the Server. 

All communications still goes through the E-speak infrastructure to insure security, 
accounting and mitigation. 

Some of the more important classes are: 

• ESContact 

• EsVocabulary 

Some of the more important methods deal with finders: 

• Vocabulary finders 

• Contract finders 

• Service finders 

• Folder finders 

Web Access 

Web access provides the interface for E-speak to standard environments in the 
Internet and XML-based e-Services solutions. Of particular interest are: 

• Provide access to e-speak services through standard web browsers, 



Developer Release X.03.03.00, September 2000 



17 



E-Speak Programming Interfaces 



Introduction 



• Enable e-speak services acting as services in the v^eb (web services) , 

• Allowing invocation of standard, non-E-speak enabled web services from E- 
speak clients, 

• Provide access from and to XML-based E-speak services, 

• Allow e-speak services to interact based on the XML document exchange model 
using various transports (HTTP, TCP, VPN connections). 

The architecture of Web Access is defined in the Web Access Architecture Docu- 
ment, Web Access internally uses "E-speak XML"^ to represent "content". 

The term "content" refers here to all kinds of information related to E-speak, 
processed by Web Access and the E-speak core. It captures functions of the E-speak 
core. 

Examples are search queries in order to find E-speak services, vocabulary descrip- 
tions, E-speak management information, service invocations and results passed 
back to requesting services and so forth. 

"Content representation" (encoding) is different at different stages in the 
system, and content needs to be transformed to interface with external systems. 

The connection points to external systems are referred to as "adapters" (inbound) 
and "agents" (outbound). 

For instance, when a user requests a service discovery through a web browser, this 
query arrives in Web Access as a HTTP FORM POST request. This representation of 
the query content needs to be transformed into internal E-speak XML for further 
processing. 

Reversely, the result represented in E-speak XML needs to be transformed into 
HTML as expected by the browser an sent back in the HTTP reply message. Prima- 
rily for the browser interface, content needs to be presented visually. "Content 
presentation" is a special kind of a transformation and is based on XSL style 
sheet transformations. 



I "E-speak XML" refers to XML in accordance with the E-speak DTD/Schema definition 
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Comparing the Interfaces 

Often, the first question to arise is whether to use the Web Access (XML) base inter- 
face or Jesi (Java) based interface. Both provide similar functionality but with 
totally different paradigms. 

The Java Model is oriented toward traditional API interfaces. 

Services are described by having an API or a set of APIs. 

The client can make calls to discover services, retrieve a stub object and then 
invoke the services. These are typically synchronous methods with calls to methods 
producing results which the client will wait on. 

The XML Model, on the other hand is a document based interface that is fundamen- 
tally asynchronous. 

Services are described not by a set of APIs, but by a Schema which describes a set 
of XML documents which those services can understand. 

To find a service, a document defining the query for Services is sent to Web Access 
which will then return a document describing the Services which fit the query crite- 
ria. 

Considerations 

Computational Services 

Computational Services fit well with the API style (Java) Model. For instance, the 
Virtual File System is based on the Java model and exposes a core set of functional 
methods (Read, Write, Open, Close) which can be invoked by a client. 

Business Services 

Informational, business or broker type services fit well with the document mode. 

The API Model typically assumes that the programmer has knowledge of the exact 
interface at programming time, usually through importing the IDL definitions at 
compile time to generate the stubs needed. This means that the interface must 
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remain immutable though the life of that version of the client. If the interface 
changes or is extended, the clients must be recompiled to handle or take advantage 
of the changes. 

Changes or extensions in the document model can be discovered by the Client when 
it downloads the Schema. On the one hand the document model requires some addi- 
tional effort in parsing the Schema and handling different formats for documents, 
but on the other hand this allows greater flexibility for the Client software since it 
is possible to handle a wider range of changes with recompiling. 
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About This Document 

This document describes the E-speak Service Interface for Java programmers 
(J-ESI), pronounced J-Easy, that is used by Clients to program on the e-speak 
infrastructure. The document explains the programming model for Clients of the 
e-speak infrastructure. This document contains the following chapters: 

• Chapter 2 provides an overview of the J-ESI, the programming model, and the 
different Services provided in e-speak. 

• Chapter 3 explains how to connect with e-speak, and how the Client and the 
Service provider create and use Services. 

• Chapter 4 explains folders, communities, categories, security, views, and events. 

• explains thread-safe programming concepts. 

• describes the messaging Application Programming Interfaces (APIs). 

• describes the command line invocation of the IDL compiler. 

• describes the interceptor mechanism in J-ESI. 

• describes the account manager in J-ESI. 

• describes the security bootstrap mechanism. 

• describes how services can be deployed and accessed across firewalls. 

• describes how to create managed e-speak services and monitor them. 

• describes the classes of checked exceptions that can be thrown by the J-ESI. 
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Introduction 

Traditionally, distributed applications have been viewed as applications that are 
run over multiple computers in a local domain. As a result, distributed 
environments have been geared toward tightly coupled applications. However, 
these environments do not meet the requirements of application deployment and 
interaction in the Internet domain. 

Applications in the Internet domain are better characterized as Services. A Service 
is a piece of software that is not tightly coupled with Client applications. Services 
are dynamically discoverable and composable entities. E-speak allows building 
such loosely coupled, distributed services by supporting the notion of a Service 
interface, a Service description that enables Services to be discovered, and by 
mediating access to Services. 

The e-speak infrastructure provides clear segregation of the roles played by 
different entities in enabling a robust Service ecosystem. The entities involved in 
defining Service ecosystems are categorized as follows: 

• Service standards bodies: Standardization bodies define and publish 

standardized interfaces for different Service categories that are used by Service 
developers to write Services conforming to the standardized interface. 

For example, a standards body may define a generic printer Service interface to 
contain the following invocation points: print 0 » and status 0 . Any Service 
provider interested in providing a printer Service writes their Service to support 
this interface. 

In addition, the standardization body is responsible for identifying the Vocabu- 
lary used to describe a Service. The Vocabulary describes the attributes that are 
used to uniquely describe a Service. For example, a printer Vocabulary includes 
attributes such as Manufacturer, Modelname, DPI and so on (perhaps using 
XML) that is used by service deployers to advertise this Service, and queried by 
Clients to discover it. 
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• Service developers: These are the developers of the actual Service 
implementation. Service developers design their Service to comply w^ith the 
programmatic Service interfaces published by the standards bodies. Service 
developers are also able to wrap existing legacy applications so that they can be 
made available as services in the e-speak infrastructure. 

• Service deployers: Service deployers are responsible for deploying the Services 
created by the Service developers. They are responsible for advertising the 
Services in the appropriate Vocabulary and also for handling requests to the 
Service. 

• Service administrators: These administrators are responsible for monitoring, 
administering, and controlling the Service deployment. 

• Service Directories: These directories are places where service providers and 
clients can advertise and find other services that are of interest to them. 

This segregation of roles allows the Service developers to concentrate on the 
business logic of the Service that they are developing, the Service deployers to 
concentrate on advertising and handling requests to the Service, and the 
administrators to administer the Service. Furthermore, the existence of service 
directories greatly simplifies the process of building new composite services by 
providing a place where services can find other services. An example of such a 
service directory is accessible from the e-speak.hp.com site that each e-speak 
installation points to by default. 

J-ESI acts as the Java system call interface to the e-speak Core for all the above 
entities. The Core is the active entity of e-speak that acts as the mediation layer and 
routes messages to Services. 

Figure 5 shows a typical interaction between Clients and Service providers in an 
e-speak community. An e-speak community consists of a number of Cores 
connected to each other. Clients and Service providers join the community through 
these Cores. 

Clients search for Services registered in the community, and when they are 
successful they gain access to the Service using a Service proxy (stub) of the 
discovered Service. 

The Clients need to know only the interface of the Service in order to invoke object- 
oriented functions (methods) on it. 
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Figure 5 Typical interaction between Clients and Service providers 

Unlike other distributed computing infrastructures, where the infrastructure is 
used only to locate the remote stub, in e-speak all subsequent accesses are 
mediated by the infrastructure. This mediation allows the infrastructure to enable 
very flexible security mechanisms that can be used to implement a wide variety of 
security policies. It also permits better management of the Services in the 
community for accounting, auditing, and billing purposes. The e-speak architectural 
specification has a description of the security features in e-speak. However, this 
release of J-ESI exposes only few security-related APIs. 
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Programming Model 

The primary goal of e-speakk is to simplify the development, deployment, and 
management of communities of Services on the Internet. To accomplish this, e- 
speak provides three basic abstractions: 

• Services 

• Service Contracts 

• Service Vocabularies 

In addition to these abstractions, e-speak provides system Services that enable 
Clients to write e-speak Services using J-ESL 

E-speak Services 

Essentially, Services are programs written in a programming language such as Java, 
C, Perl, and C++. Although J-ESI makes use of some Java features, the e-speak 
infrastructure itself is not limited to any particular language. For example, a Service 
registered using J-ESI can be accessed from a Perl/P)1:hon script by using the 
appropriate e-speak library. Figure 6 illustrates the relationship between Services, 
their Contracts, and their Vocabularies. 
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Figure 6 Relationships among Services, Contracts, and Vocabularies 

Any e-speak Service conforms to its Contract because by design, it implements the 
interfaces ±at are outlined in its Contract. In addition, the Service is advertised in 
an appropriate Vocabulary. 

Service Vocabularies essentially provide the scheme for constructing the 
description of the Service. All three abstractions, Services, Contracts, and 
Vocabularies, are first-class entities in e-speak. By decoupling Services from the 
Contract and the Vocabulary, e-speak allows Service implementors (who develop 
the actual Service implementations conforming to certain Service Contracts) to be 
independent of Service deployers (who simply advertise the Service in a well- 
known Vocabulary) . 
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Clients are not dependent on the Service developer and deployer to communicate 
the Service Contracts and Vocabularies with which these Services have been 
described. 

The Service deployers register their Services with a group of e-speak Cores. On 
registering a Service, this Service is discoverable by others in the same e-speak 
group of Cores. 

Clients use the default e-speak finders that are provided with J-ESI, or write their 
own finders to find Services that meet their requirements. The access permissions 
of the Service determine the Services that will be visible to the Clients. On finding 
Services, Clients receive a remote stub to the Service. 

Service Contracts 

Each e-speak Service implements a set of interfaces defined in a Service Contract. 
These interfaces are often defined using the e-speak IDL, which is similar to the 
Java-RMI IDL (See , "Messaging Classes", for additional information.) Service 
Contracts are first-class entities that can be discovered and used like any other 
Service. All Service Contracts support a base set of interfaces that provide 
mechanisms to create and query them. As a result, Contracts also can be advertised 
in a well-known Vocabulary — typically by a standardization body. 

Service Vocabularies 

A Vocabulary consists of a set of associated attributes and properties. The only 
properties associated with any attribute are the name of the attribute and the type 
of values to which these attributes are assigned. The structure of a Vocabulary is 
dependent on the vertical market for which it is defined. 

For example, the Vocabulary used to define a printer with attributes such as 
manufacturer, model name, DPI, speed, color, and cost is quite different from the 
Vocabulary that defines apparel merchandise that has attributes such as size, color, 
material, and cost. 
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Though some of the attribute names may be the same across Vocabularies, they 
may have different semantics. The attribute color in the Printer Vocabulary may be 
a boolean expression that indicates whether the printer supports color printing; 
however, the attribute color in the Apparel Vocabulary may indicate the actual color 
of the piece of clothing. 

Because Vocabularies are first-class entities, Clients and Services alike can find 
these Vocabularies registered in the community and subsequently make use of 
them. New Vocabularies are typically advertised using the Base Vocabulary that is 
available in the e-speak infrastructure. 

This Base Vocabulary defines a set of attributes that are generic and can be used by 
generic Services in markets that do not have well-defined Vocabularies. All Services 
registered as a Vocabulary conform to the Vocabulary Contract that defines the 
operations that can legally be performed on Vocabularies. 

E-speak System Services 

In addition to the base abstractions of Vocabulary, Contracts, and Services, J-ESI 
supports a set of base and extended services that makes the job of deploying and 
using Internet-wide Services simple. 

Basic Services 

These are the basic set of Services that are required to get connected to the e-speak 
infrastructure and to create and find new user-defined Services. These Services 
include the following: 

• Connection — A connection Service is used to connect and disconnect from the 
e-speak infrastructure. 

• Vocabulary — A Vocabulary Service allows the creation of new Vocabularies 
and queries the properties of existing Vocabularies. 

• Contract — The Contract Service is used to create and use Contracts. 

• Elements and Finders — Service elements are used to register Services with 
the Core, while Service finders are used to find Services. 
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Extended Services 

• Events — This Service defines a distributed Event Publisher-Subscriber model 
for Events. Events are distributed by a Distributor across any number of 
connected Cores. 

• Community — This Service enables discovery of Services across multiple 
e-speak cores. Communities are Client-side abstractions of collections of groups 
that form the search domain. The Community is a collection of member core 
groups identified by group names. 

• Folders — The Folder Service allows users to manage their Services (discovered 
or created) similar to how they manage local files in a standard operating 
system. Persistent folders appear on reconnecting and act very much like 
organized hierarchically persistent bookmarks. 

Client-Service Interaction 

As described earlier, Clients find a Service using attributes described in the Service 
Vocabulary. The return value of the find ( ) call is a Service stub that extends 
ESService and implements the operational interface specified in the find. 

When Clients discover a Service, they have to specify the interface they want to use. 
The stub is the Client-side abstraction of a Service that implements this interface. 
The Service provider s abstraction of the Service is a Service element as 
represented by the class ESServiceElement, 

The Service element has, among other things, the description of the Service, the 
description accessor of the Service to mutate the description, and the actual 
implementation of the Service. It also has information about the handler of the 
Service, including the queue on which messages to this Service will be sent and the 
number of threads servicing requests to this Service. 

For example, if a Service provider wants to make an existing, stand-alone 
application (such as PrinterSeirvicelmpl), an e-speak Service, performs the 
following actions: 

1 Define or modify the interface that describes the Service interface to conform to 
e-speak IDL, 
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2 Create a new ESServiceElement. 

3 The Service deployer provides the description of the Service in a Vocabulary, 
along with the implementation of the Service such as the object 
PrinterServicelmpl to the Service element The element also contains the 
description accessor of the Service that can be used by the deployer to query or 
modify the description of the Service. 

4 After performing these actions, the deployer can use the Service element to start 
the Service. The deployer can also control the concurrence of the Service by 
changing the number of threads that process the requests for this Service. The 
message queue and threads are controlled by a Service handler. 

Clients, on the other hand, create instances of a stub to the Service when they do a 
find by using the e-speak finder service. They typically refer only to the interface 
that the stub implements and invoke methods in that interface. Clients could also 
choose to use the messaging APIs to communicate with Services. 



A Simple Example 

The following section provides a simple example of an e-speak Service written 
using J-ESI that illustrates some of the basic ideas in the e-speak infrastructure. 

Client Service Discovery 

A Client first creates a new connection to an e-speak Core. After connecting to the 
Core, the Client can look up or register Services. The Client locates a Service that 
satisfies a constraint expressed with attributes in the default Vocabulary. The result 
of the find Service is a stub (or pro?^) to the Service provider s Service. Clients can 
use this stub as a network object reference and directly invoke methods on the 
Service (see Figure 7). 
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Service provider 



Figure 7 Client and provider Core relationship 

Client Service Usage 

Clients interact with the Service with the set of interfaces for which stubs are 
available in the Client address space. Clients can preinstall the Service stubs that 
are generated using the e-speak IDL stub generator, or they may acquire the stub 
class from the Service provider by other means. From the Client s perspective, the 
nature of the Service provider is insignificant beyond the requirement that it 
implement the interface and that its attributes satisfy the query that the Client 
made. 

When a Client invokes an operation, a well-defined e-speak custom serialization is 
used to ship the invocation to the target Service through the mediating e-speak 
infrastructure. In so doing, all method invocations are effectively mediated. This 
remote invocation will work across languages and platforms, because the basic 
architecture does not depend on Java. The following code fragment illustrates a 
very simple fmd-and-use scenario. The Client finds a Service whose name is 
printer and invokes the print method on it 
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ESConnection coreConnection = new ESConnection ( ) ; 
String intfNatne = PrinterServicelntf .class .getName () ; 
ESServiceFinder printFinder = 

new ESServiceFinder (coreConnection, intfName) ; 
ESQuery printQuery = new ESQuery ( "Name == 'printer'"); 
PrinterServicelntf printer = 

(PrinterServicelntf ) printFinder . find (printQuery) ; 
printer .print (document) ; 

Figure 8 shows that the e-speak Core is located between the Client and the Service 
provider. In general, many Cores may lie between the Client's Core and the Core 
where the Service provider is registered. 




Figure 8 The e-speak Core 
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Service Creation 

A Service provider is primarily interested in implementing a Service interface to 
comply with the Contract and in advertising the Service in an appropriate 
Vocabulary. The Service provider first connects to the e-speak Core. The provider 
then creates a Service element with a description of any Service Vocabularies and 
Contracts. 

The register 0 method of ESServiceElement is used to register this Service with 
the e-speak Core. The Service element object also supports certain management 
APIs that allow the Service provider to start, stop, and query the status of the 
Services encapsulated in this Service element: 

ESConnection coreConnection = new ESConnection { ) ; 
ESServiceDescription printDescription = new 
ESServiceDescription { ) ; 

printDescription . addAttribute ( "'Name" , "printer" ) ; 
ESServiceElement printElement = 

new ESServiceElement (coreConnection, printDescription) ; 
PrinterServicelmpl printerlmpl = new PrinterServicelmpl () ; 
printElement . set Implementation (printerlmpl) ; 
ESAccessor printAccessor = printElement . register () ; 
printElement . advertise ( } ; 
printElement . start ( ) ; 

This code fragment creates a simple Service called printer that is implemented 
by a class called PrinterServicelmpl. The only attribute used in this example 
is the name of the Service that is set using the addAttribute method of 
ESServiceDescription. Clients can create more complex descriptions using 
custom Vocabularies, which are described in later chapters. 

Once the start method in the Service element has been called, the printer Service 
is available for other Clients in the community to access. The actual implementation 
of the Service is independent of the e-speak infrastructure. In fact, the 
implementation can very well be legacy code potentially written in any language. 

The advertise call in the code causes the description of the service to be advertised 
in the advertising directories that have been set up. By default, J-ESI advertises the 
description of the service to the e-services village service directory. Note that the 
advertising service has to be started separately in order for the advertise call to 
function appropriately. 
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Complete Example 

This section puts together the basic ideas of e-speak into a simple end-to-end 
example that illustrates the sequence of steps that have to be taken on the Service 
provider and Client side to provide and access Services. 

Typically, users have access to the IDL that defines the interface that the Service 
implements. In this example, the Clients and Service providers are assumed to have 
installed the stubs by virtue of having access to the IDL file as well as the IDL 
compiler. Although dynamic loading of the stubs is not directly supported, it can be 
implemented in user applications using standard Java class loaders, and will also be 
supported in the next J-ESI release that incorporates the e-speak security features. 

The e-speak IDL is similar to the Java-RMI IDL. Therefore, the contents of the IDL 
files look similar to Java interface files. These IDL files must have a .esidl extension 
for the IDL compiler to recognize them as e-speak IDL files. The IDL specifications 
are found in , "Messaging Classes". 

PrinterServicelntf. esidl 

The following is a sample esidl file that defines the interface to a printer Service that 
has two methods: status and print. 

public interface PrinterServicelntf { 
public String status () 
public void print (String text) 

} 

The IDL compiler generates the following files, all of which are used by J-ESI: 

PrinterServicelntf . j ava , 
PrinterServiceStub , java, and 
PrinterServiceMessageRegistry. java 

Except for some minor changes, such as marking the generated interface as an 
e-speak interface, the Service PrinterServicelntf .java is a copy of 
PrinterService . esidl . 

Pr interServiceStiib . j ava is the stub class that the finder returns to the Client 
when it finds a Printer Service. 



34 



Developer Release X.03.03.00, September 2000 



The Basics 



A Simple Example 



For every method defined in the interface, the stub class contains code to create a 
message, marshal parameters, and send it to the Service provider. 
PrinterServiceMessageRegistry . j ava does not need to be used by the 
Client directly, but is used by J-ESI. 

PrinterServlcelmplJava 

When the IDL file is passed through the IDL compiler for Java, it produces an 
equivalent Java interface file. The Service implementor implements this Java 
interface. Therefore, the Service implementor s class (using 
PrinterServicelmpl as an example) looks as follows: 

public class PrinterServicelmpl implements PrinterServicelntf 

{ 

public String status { ) 

throws ESInvocationException 

{ 

// Implementation to return the printer status 

} 

public void print (String text) 
throws ESInvocationException 

{ 

// Implementation to print the document sent by user 

} 

} 

The Service deployer advertises the Service and handles requests to the Service, 
The foUovrtng code fragment is written by the Service deployer: 

public class PrintServer 

{ 

public static void main (String [] args) 

{ 

try 

{ 

ESConnection core Connect ion = new 
ESConnectionC'file.pr") ; 

ESServiceDescription printDescription = 

new ESServiceDescription 0 ; 
printDescription . addAttribute { "Name" , "printer" ) ; 
ESServiceElement printElement = 
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new ESServiceElement (core Connect ion, 
printDescription) ; 

printElement . set Implement at ion {new 
PrinterServicelmpl {) ) ; 

printElement . register { ) ; 

printElement . start ( ) ; 

System.out.println{ "Started printer Service ") ; 

} 

catch (Exception e) 

{ 

// handle the exception 

} 

} 

} 

The Client also runs the IDL compiler to generate the interface and stub files, and 
makes use of the interface in the program. For instance, a Client discovers and uses 
the printer as follows: 

public class PrintClient 

{ 

public static void main (String [] args) 

{ 

try 

{ 

ESConnection coreConnection = new 
ESConnectlon ("f ile.pr'M ; 

String intfName = PrinterServicelntf . class .getName () ; 
ESServiceFinder printFinder = 

new ESServiceFinder (coreConnection, intfName); 
ESQuery printQuery = 

new ESQuery ( *'Name == 'printer'"); 
PrinterServicelntf printer = (PrinterServicelntf) 

printFinder . find (printQuery) ; 
String document = get Document ( ) ; 
printer .print (document) ; 
System. out. print In (printer. status {) ) ; 

} 

catch (Exception e) 

{ 

// handle the exception 

} 

} 

} 
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This class is all that is required of a client application developer to find and use an 
example printer service. 
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This chapter explains the basic Services available within e-speak. The chapter 
contains the following sections: 

• Getting Connected to E-speak 

• E-speak Services 

• Client: Finding Services 

• Service Deployer: Creating Services 

• Service Description 

• Accessing Descriptions: ESAccessor 



Getting Connected to E-speak 

The simple example in Chapter 2, "The Basics" shows that pure Clients (e-speak 
Clients who use found Services rather than creating their own Services) and Service 
providers who provide Services have to connect to the e-speak infrastructure to 
access or provide Services. Because both pure Clients and Service providers are 
Clients of the e-speak infrastructure, they are often referred to collectively as e- 
speak Clients. 

ESConnection 

In J-ESI, the connection between Clients and the e-speak infrastructure is 
represented by an ESConnection. Clients create a new instance of 
ESConnection when they want to connect to the e-speak infrastructure. Clients 
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insert all of the relevant information needed for connecting to the e-speak 
infrastructure in a configuration file that is passed as an argument to the 
constructor of the ESConnection. 

The default constructor for the ESConnection connects to an e-speak Core that is 
running on the local machine and is listening to requests on a port defined in the 
ESCons tants file. Clients can also insert the name of a properties file that has the 
values of the properties that are relevant to establishing the connection. The most 
common fields in this property file are listed in the next subsection. 

When a connection is established between a Client and the e-speak Core, the 
capabilities granted to operations performed on this connection depend on the 
credentials that are presented. For example, if a user connects to a Core as a guest, 
the user receives restricted access and privileges compared to a user logged in as 
an administrator while operating from that cormection. 

ESConnection supports APIs that return the Base Vocabulary and Contract 
Services. In addition, there are other APIs for getting management-related 
information that identifies users and the Core. The ESConnection also 
encapsulates the context of the actions that are performed by the Client. 

Property Files 

The property file parameter passed to the ESConnection constructor provides 
values for the properties that are required to connect to the e-speak inft-astructure. 
For example, the property file has entries for the following properties: 

• username 

This property specifies the name of the user who is connecting to the e-speak 
Core. If the property file does not provide a value for this, the default value that 
is used is guest. 

• password 

This is the password of the user. The password along with the username form 
the user credential. 

• esurl 
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This is a colon-separated string that specifies the conununication channel 
between the Client and the Core. For example, 

tcp : rgelpc032 . rgv . hp . com: 12346 specifies that the Client connects to 
the Core running on host rgelpc032 . rgv , hp . com on port 12346 using tcp 
as the communication protocol 

• protocol 
hostname 
port number 

When the esurl is not specified, the Client can alternatively specify the 
elements of the connection information by explicitly specifying the protocol, 
host name, and port number. If the configuration file does not have the protocol, 
the default value for the protocol is tcp. Furthermore, if the property file does 
not have a value for the host name, the default value for the host name is local - 
host, and the default port number is 12346. 

• accountname 

Clients can provide names for their accounts so that they can reconnect to the 
same account when they connect the next time. 

• homefolder 

Applications can specify their home folder. This folder is the current working 
folder when the connection is made to the e-speak Core. 

• Timeouts 

Applications may be able to specify timeouts for various calls. Synchronous call 
timeouts can be specified with synchronous_call_timeout. Asynchronous 
call timeouts can be specified using asynchronous_send_timeout. Service 
providers can specify timeouts for messages they receive using 
asynchronous_receive_t imeout. Clients can time out their find calls 
using f inder_t imeout . Timeouts are specified in milliseconds. Timeouts 
can also be changed dynamically. This can be done by calling the following 
methods on ESConnect ion . 

- setCallTimeout (int value); 
- setAsyncSendTimeout (int value); 
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- setAsyncRecvTimout {int value); 

- setFinderTimeout (int value); 

• eventcontrol 

This property specifies the default event control for the services being regis- 
tered. If the eventcontrol property is " 0 " then the core will generate an 
event when the service metadata is mutated. If it is "l" then the core will not 
generate events for service mutation. 

Connection Configuration 

Typically, Clients create an instance of an ESConnection as follows: 

ESConnection core Connect ion = new ESConnection {) ; 

This API connects to the core running on default hostname, which is the localhost, 
and default port, which is 12346. This API is deprecated and using ESConnection 
constructor with a property file is recommended. In this case, a transient guest 
account is created and as soon as the connection is closed, this instance of the guest 
account is removed. Alternatively, the client can connect to the Core using 

string propertyFileName = new String ( "/users/connection. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

When the property file is used for creating a connection and the account name 
property in the property file is used, the following account creation rules are 
followed: 

• Where the account name property is not specified, a transient guest account is 
created. However, if the account name is provided and no previous account of 
this name exists, a new account with the user and password is created. 

• Where the account already exists and the user credentials are validated, the 
connection returns a connection with the last saved state associated with the 
same user credential. 

After having connected to the Core, the Client can retrieve the parameters of the 
connection by entering 

ESConf iguration config coreConnection.getConf iguration () ; 
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The following methods in the ESConf igurat ion class allow the Client to retrieve 
the various parameters of the connection: 

public class ESConf igurat ion 
{ 

public ESUserCredential getUserCredential {) ; 
public String getHostName () ; 
public int ge t Port Number () ; 
public String getProtocol 0 ; 
public String getURLO; 

public void setHostName {String hostName) ; 

public void setPortNuinber (int portNumber) ; 

public void setProtocol (String protocol); 

public String getConnectionName ( ) ; 

public void setConnectionName (String name) ; 

public String getGroupName ( ) ; 

public void setURL (String url) ; 

public int getCallTimeout () ; 

public int setCallTimeout ( int newVal ); 

// refer to javadoc for other methods 

} 



E-speak Services 

There are two abstractions for a Service: 

• Service providers— Service elements (ESServiceElement) that are used by 
Service providers to deploy and manage a Service, 

• Clients— Service stubs (ESService) that are used by Clients to access an e- 
speak Service. 

Service providers take the following steps to create a Service: 
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1 The Service developer provides implementation of the Service interface. These 
interfaces are encapsulated in the Contract to which the Service conforms. The 
actual implementation need not contain any e-speak-specific code. 

2 The Service deployer then describes the Service in a chosen Vocabulary by 
setting the attribute values appropriately. The ESServiceDescript ion class 
is used to set these attribute values. 

3 The Service deployer and/or administrator then creates a new 
ESServiceElement that registers and starts the Service so that other Clients 
of the e-speak infrastructure can find and use the Service. (See Figure 9.) 



implement 



E^erviceEletmfm 



creaii f$. 




PrinterServicelntf 
»^ 



PrinterServicelmpl 



Accessor 



ESServiceDescription 



ESServic« 



finds 



implements 



PrinterServiceStub 




returns 


— ESServic 







Figure 9 Creating an ESServiceElement 

Clients typically take the following steps to find and use a Service: 

1 Clients find Services using a Service finder that accepts queries in the 
Vocabulary that was used to advertise the Service. Clients also specify the 
interface that they expect to use to invoke the Service. 

2 On finding a match, the Clients get a handle to a Service stub that can be used to 
invoke ±e methods that are implemented by the Service provider (see Figure 9). 
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The Client or Service deployer can choose to examine or modify attribute values. 
This is accomplished using the ESAccessor class. 

All the three basic entities (Vocabularies, Contracts, and other Services) in e-speak 
can be created or found in the same manner. 

The main difference between generic Services and Contracts or Vocabularies is that 
the interface for Vocabularies and Contracts is defined by the e-speak Core. The 
Core is the handler for any Vocabulary or Contract method. 

Generic Services on the other hand, are not handled by the Core, and can have 
arbitrary interfaces that meet the requirements of the specific Service. The rest of 
this section describes the well-defined interfaces supported by Contracts and 
Vocabularies in the e-speak Core. 

ESContract 

Just as a Vocabulary determines the scheme for describing the attributes of 
Services, the Contract determines the type of Service as represented by the 
interfaces that it implements. Just as the Core is the handler for Vocabularies, the 
Core is the handler for Contracts as well. 

The following method returns the name of the Contract; the name of the interface 
that this Contract encapsulates: 

public String getlnterf aceName ( ) ; 

The following method returns the IDL string associated with the Contract: 

public byte [] getlnterf aceDefinition () ; 

In addition, the ESContract has methods that return the conversations that the 
service supports, the terms and conditions of use, and the license policy. The 
following entry points in ESContract are the relevant entry points. 



public String getConversationScheme ( ) ; 
public String getTermsOf Use ( ) ; 
public String getLicense () ; 
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Base Contract 

A Base Contract is available in the Core that Clients can obtain by invoking the 
getBaseContract method in the connection object For example: 

string propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection ~ new 
ES Connect ion (propertyFileName) ; 

ESContract baseContract = coreConnection .getBaseContract {) ; 

ESVocabulary 

In the e-speak infrastructure. Vocabularies are also Services that are discovered by 
Clients. When the Client discovers a Vocabulary, the Client receives a stub that 
conforms to the ESVocabulary interface. However, the Service provider for the 
Vocabulary is the e-speak Core itself. 

After a Vocabulary has been defined. Clients of the Vocabulary can only query its 
contents to determine what properties this Vocabulary defines. The Clients cannot 
change the properties of the Vocabulary. Furthermore, they can query the core for 
all the services that are registered in this vocabulary. There are two main APIs in 
ESVocabulary: 

public ESProperty[] getProperties () ; 
public ESAccessor[] getServices () ; 

The conversation scheme, terms of use, and licensing policy are not available for 
the base contract. 

Base Vocabulary 

The Base Vocabulary comes preloaded with e-speak. This Base Vocabulary has pre- 
defined properties that can be used to describe Services. Service providers do not 
have to invent their own Vocabulary to describe their simple Services. The Base 
Vocabulary has basic attributes that can represent the name of the Service, the type 
of Service, and other similar characteristics that are universal to many Services. 

The base Vocabulary can be retrieved from an ESConnection using the 
getBaseVocabulary ( ) method. The following code fragment shows how 
Clients get the Base Vocabulary: 
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string propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESVocabulary baseVocab = coreConnection .getBaseVocabulary {) ; 

The following table shows some of the important properties that are defined in the 
Base Vocabulary. No other vocabulary should define and use *Name\ Type* and 
'ESGroup* as these attributes are reserved and are used by the J-ESI library 
internally. 



Table 3 Base Vocabulary properties 



Attribute name 


Type 


Description 


Name 


String 


Name of the Service 


Type 


String 


Type of Service 


ResourceStibType 


String 


Subtype of Service 


Description 


String 


Description of the Service 


Version 


String 


Version of the Service 


ESDate 


Date 


Date associated with the Service 


ESGroup 


String 


Group associated with the Service 


ESTimestamp 


Timestamp 


Timestamp associated with the Service 


ESCategory 


String 


Stringified list of categories that any 
service is advertised in. 



Client: Finding Services 

Clients to the e-speak Core typically find Services that match certain constraints. 
The kinds of finders are visible to the Client are: 
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• Vocabulary finders 

• Contract finders 

• Service finders 

• Folder finders 

• View finders 

You can extend these finders to suit your needs or to use the APIs supported in 
these classes directly. 

Setting Search Level in Finders 

The following search level operations are possible in the finders .These methods are 
present in the abstract class ESAbstractFinder and are visible to all the derived 
finder classes such as ESServiceFinder and ESContractFinder: 

public void setMaxToFind (int maxToFind) 
public int getMaxToFind ( ) 

Using the above set method, it is possible to set the number of maximum services 
that should be returned as a result of a fmd call The get method returns the current 
setting. The default maximum value is 1000. 

public void setSecurityLevel (boolean flag) 
public boolean getSecurityLevel () 

Passing a true in the above set method enables stub classes to be dynamically 
downloaded from the service provider. Passing a false will allow classes to be 
loaded only from the local classpath. The getter returns the current settings for the 
security level. By default, the stub classes will be loaded only from the local 
classpath. 

public void setSearchLevel {int flag) 
public int getSearchLevel ( ) 

The above methods allow the user to set the level for searching the services. Passing 
ESConstants . LOCAL_ONLY will restrict the search for services to the local core 
repository irrespective of the community settings. ESConstants . LOCAL_ADV 
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will restrict the search to local repository and local group. 
ESConstants . ADV_ONLY will result in the search being conducted in the 
community. The default is that the search will be conducted in LOCAL_ADV mode. 

ESContractFinder 

The ESContractFinder class is used by Clients to find Contracts. Contracts are 
Services that are registered with the e-speak Core just like any other Service. The 
Contract Finder finds only Services that have been registered as Contracts. The 
attribute that is used to distinguish between Contracts is the Name attribute in the 
Base Vocabulary. There are three important entry points in ESContractFinder. 
These are: 

public ESContract find(ESQuery query); 
public ESContract [] f indAll {ESQuery query); 
public ESContract [] findWextO; 
public void setMaxToFind {int number); 

The find method finds a single contract that matches the constraints and 
preferences in the query. The find All finds all contracts that match the query subject 
to the maximum number of services set in the finder. 

For example, to find a Contract named PrintContract, use the following code 
ft*agment: 

String property? ileName = new String { "/users/connection. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESContractFinder printContractFinder = 

new ESContractFinder (coreConnection) ; 
ESQuery printContractQuery = 
new ESQuery ( ''Name == ^PrintContract'"); 
ESContract printContract = 

printContractFinder . find (printContractQuery) ; 
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ESVocabularyFinder 

The ESVocabularyFinder class is used by Clients to find Vocabularies. Finding 
a vocabulary is done more often than creating a vocabulary. Vocabularies are 
usually defined by some standard body. For example, a standard body might define 
a printer vocabulary which contains attributes like the speed of the printer, its 
location, etc. The definition of the vocabulary happens only once. It is likely that 
this vocabulary is registered in a community of interest. Any printer which wants to 
conform to this standard body finds the vocabulary and registers the printer service 
using this vocabulary. 

Because a vocabulary is also a service, it needs to be advertised as well. Usually 
vocabularies are advertised in the default vocabulary. It is also possible to advertise 
a vocabulary in another non default vocabulary. 

public ESVocabulary find(ESQuery query) ; 
public ESVocabulary [] f indAll (ESQuery query); 
public ESVocabulary [] f indNext ( ) ; 
public void setMaxToFind (int number) ; 

For example, to find a Vocabulary named printerVocab, use the following code 
fragment: 

String propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESVocabularyFinder printVocabFinder = 

new ESVocabularyFinder (coreConnection) ; 
ESQuery printVocabQuery = 

new ESQuery ( ''Name 'printerVocab' " ) ; 
ESVocabulary printVocab = 
printVocabFinder . find (printVocabQuery) ; 

Instead of using ESQuery, you can find a vocabulary using an XML query using 
ESXMLQuery. 
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ESServiceFinder 

The ESServiceFinder class is a generic finder class that is used to find user- 
defined Services. The interfaces here look similar to the ESContractFinder and 
ESVocabulary finder. 

piiblic ESService find{ESQuery query); 
public ESService [] f indAll (ESQuery query); 
public ESService [] findNextO; 
public void setMaxTof ind (int number); 

The ESServiceFinder class has two constructors. One constructor which takes 
only ESConnect ion as parameter, find/f indAll in this case will return the base 
stub (ESService) firom which all other stubs derive. The second constructor takes 
ESConnect ion and the interface name (or ESContract) as parameters, find/ 
f indAll in this scenario returns the stub for the Service provider. When the 
interface name is specified for doing a find, the client library sends an introspection 
request to the potential service providers. The service providers that respond 
correctly to the introspection request are returned as results. This means that when 
the interface name is used in the find, the services that the finder returns were 
known to be up and ready at the time of the find. No such guarantee can be made 
when the finder is used without the interface name. If the Service provider is not 
running, the call times out if the finder timeout is set. More details on how to set the 
timeouts is available in the later sections. 

The ESServiceFinder class can return multiple Services as the result of a query. 
However, Clients can control the maximum number of Services that are returned as 
the result of a find by entering the following code: 

public void setMaxToFind {int number); 
public int getMaxToFind { ) ; 

Chapter 2 presented an example of a Client that searches for a simple printer that 
is described in the base Vocabulary. A slightly more complex example of a Printer 
that has been advertised in a non-Base Vocabulary, called a printerVocab, 
requires the following code to find the printer: 

public class PrintClient{ 
public static void main (String [] argv) { 
try { 

String proper tyFileName = 

new String CVusers/connect ion. prop") ; 
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ESConnection coreConnection ~ 

new ESConnection (propertyFileName) ; 
// find vocabulary 

ESVocabularyFinder printVocabFinder = 

new ESVocabularyFinder (coreConnection) ; 

ESQuery printVocabQuery 

new ESQuery (^^Name -= ^ Print Vocab' ") ; 

ESVocabulary printVocab = 

printVocabFinder . find (printVocabQuery) ; 

// find contract 

ESContractFinder printContractFinder = 

new ESContractFinder (coreConnection) ; 
ESQuery printContractQuery = 

new ESQuery ( ^'Name ' PrintContract ' " ) ; 
ESContract printContract = 

printContractFinder . find (printContractQuery) ; 
// find service described in vocab that conforms to 
contract 

ESServiceFinder printFinder = 

new ESServiceFinder (coreConnection, printContract) ; 
ESQuery printQuery = new ESQuery (printVocab) ; 
printQuery.addConstraint (''DPI == 1400"); 
PrinterServicelntf printer = (PrinterServicelntf ) 

printFinder. find (printQuery) ; 
String document = getDocument { ) ; 
printer .print (document) ; 
} catch (Exception e) 

{ 

// handle the exception. 

} 

} 

} 

The finder class also supports a cursor like mechanism for clients to traverse the 
result set obtained as a result of performing a f indAll ( ) operation. The cursor 
mechanism is quite common in relational database APIs such as JDBC. In JDBC, the 
result of executing a query is a result set, and the client program can loop based on 
a condition that depends on whether there are additional rows in the result set. In 
J-ESI, on the other hand, the finder itself acts as the result set. On invoking a 
f indAll ( ) operation on the finder, the finder acts as a cursor. The client program 
can determine whether there are other services found by the finder by invoking the 
hasMoreResults ( ) method on the finder. In addition, the next set of results can 
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be obtained from the finder by invoking the f indNext ( ) method. In the example 
below, the query essentially finds all the services that are registered in the printer 
vocabulary. It then proceeds to retrieve the services that are found two at a time. 



33public static void main ( String [] args ) { 
try { 

String propertyFileName ^ new String ( "/users/ 
connect ion. prop " ) ; 

ESConnection conn = new ESConnec t ion (propertyFileName) ; 
ESVocabularyFinder vf = new ESVocabularyFinder (conn) ; 
ESVocabulary v = null ; 
try { 

V = vf.find( new ESQuery ( "Name == »printerVocab ' " ) ) ; 
} catch ( LookupFailedException ffe ) { 
f f e .printStackTrace ( ) ; 
return; 

ESServiceFinder finder = new ESServiceFinder (conn) ; 
ESQuery query = new ESQuery (v, " (Name === 'printer') or (Name 1 = 
•printer' ) ") ; 
ESService[] serviceList = null; 
int total_f indall_services = 0; 
finder . setMaxToFind ( 2 ) ; 
serviceList = f inder . findAlK query) ; 
total_f indall_services += serviceList . length; 
while (finder .hasMoreResults {) ) { 
serviceList = finder . f indNext ( ) ; 

// . . do stuff with services found in service list. 
System.out. print In ("number of services got: " + 
serviceList . length) ; 

} 

} catch ( Exception ex ) { 

exl .printStackTrace ( ) ; 

} 

return; 

} 



Developer Release X.03.03.00, September 2000 



53 



Client: Finding Services 



Basic Services 



ESQuery 



In general, Clients use the ESQuery class to construct queries that are either not 
simple name lookups in the Base Vocabulary or are constraints that are expressed 
in a Vocabulary that is different from the default Vocabulary. The ESQuery class has 
methods that allow the client to add constraints that make up the query. These 
constraints are string constraints whose syntax is similar to the syntax of constraint 
specification in OMG s OTS specification. Essentially, every constraint is parsed as 
if it were a disjunction of conjunctions, i.e., the constraint expression is expected 
to be in disjunctive normal form. 

More formally, the context-free grammar that defines the syntax of the constraint 
strings is as follows: 

<Expr> : : = <OrExpr> 
<OrExpr> : := <AndExpr > 

I <OrExpr> 'or' <AndExpr> 
<AndExpr> : : = <NotExpr > 

I <AndExpr> 'and' <NotExpr> 
<NotExpr> : :- <EqualityExpr> 
I 'not' <EqualityExpr> 
<EqualityExpr> ::= <RelationalExpr> 

I <RelationalExpr> ( <OpEqual> | ' !=' ) <RelationalExpr> 
<RelationalExpr> : := <InExpr> 

I <InExpr> <OpRelational> <InExpr> 
<InExpr> <AdditiveExpr> 

I <AdditiveExpr> 'in' <AdditiveExpr> 

I <AdditiveExpr> 'in' <ListExpr> 
<AdditiveExpr> <MultiplicativeExpr> 

I <AdditiveExpr> <OpAdditive> <Mult iplicativeExpr> 
<MultiplicativeExpr> : := <UnaryExpr> 

I <MultiplicativeExpr> <OpMultiplicative> 

<UnaryExpr> 

<UnaryExpr> : := <UnionExpr> 

I ' - ' <UnaryExpr > 

j ^ exist' <PathExpr> 
<UnionExpr> : := <PathExpr> 

I <UnionExpr> ' | ' <PathExpr> 
<ListExpr> : := ' <Arguments> M ' 
<PathExpr> ::= V 

I '/' <RelativeLocationPath> 
I V/' <RelativeLocationPath> 
I <RelativeLocationPath> 
I <FilterExpr> 
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<FilterExpr> : :- 
<RelativeLocationPath> 



I <FilterExpr> V <RelativeLocationPath> 
I <FilterExpr> V/' <RelativeLocationPath> 
< Prima ryExpr> 

I <FilterExpr> <Predicate> 



< Pr i mary Exp r > 



<FunctionCall> 
<ArguTnents> : : = 



<Step> 
<NCName> 



I <RelativeLocationPath> V <Step> 
<RelativeLocationPath> V/' <Step> 



I ' <Expr> ^ ) ' 

I <Literal> 

I <FunctionCall> 

<FiinctionName> <ArguTnents> 



<Expr> 



< Argument s > 



<Expr> 



<Predicate> : := <Expr> 
<Step> ::= <StepPredicate> 



I 



<StepPredicate> <AxisSpecif ier> <NodeTest> 



<AxisSpecif ier> 



<NodeTest> ::= 



<AxisNanie> 



I <StepPredicate> <Predicate> 



I 



e 



String_Lit ^ ) ' 
<NodeType> ::= ^comment' 
<AxisName> ::= 'ancestor' 



'namespace' 

<Qname> <NCName> 
<Literal> ::= <Number Lit> 



I <NCName> 

I <QName> 

I NodeType ' {' M ' 

I 'processing- instruction' M' 

'text' I 'node' 

'ancestor-or-self ' | » attribute' 

•child' I 'descendant' | ' descendant-or-self ' 

I 'following' | 'following-sibling' | 

'parent' | 'preceding' | 'preceding-sibling' 
I 'self 



<NCName> 



<NCName> 



<OpEqual = 



I <String_Lit> 

I <Boolean_Lit> 

I <Date_Lit> 

I <Time_Lit> 

I <TimeStamp_Lit> 
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<OpRelat zonal > : := | ^<=' | | ^>=' | ^Sdt;' | ^Sclt; = ' | ^>' | 

<OpAddtive> : : = ' + ' ] ' - ' 

<OpMultiplicative> ::~ <MultiplyOperator> | 'div' | 'mod' 
<NCName> ::= { <Ijetter> | ) ? <NCNameChar>* 

<NCNameChar> <Letter> | <Digit> | | | 

I <CombiningChar> | <Extender> 
<NuTnber_Lit> ::= <Digit>* <Digit>+ ( ( 'E' | ^e' ) ( ' + ' | 

^ ) <Digit>+ ) 

<String_Lit> ::= [ <AnyChar>^"" ]* 

I ' " [ <AnyChar>^' ' ' ] * " ' 

<Boolean_Lit> : := true ] false 

<Date__Lit> ::= { 'd' \ 'D' ) WhiteSpace* {CC ] YY? ^-^ MM? ^- 

^ DD 

<TiTne_Lit> (^f 1 ) WhiteSpace* HH ^ : ' MM ^ : ' SS 

( 

SSS S* )? (^Z' I ^ - ^ MM ^ : ' SS ) ? ^ } ' 

<TimeStaTnp_Lit> ' {' ( ^t' | ^TM ( ^s' | ^S' ) WhiteSpace* CCYY 

MM ^-^ DD ^T' <Time_Lit> 

Example query strings include: 

"TestStrl + 'String2' • StringlString2 ' and Testint - 5 < 10 and 

TestDoiable < 30" 

"TestDate > {d 1980-08-21} and TestTimestamp <=r {ts 1992-05- 

12X05:33:44.111111000}", 

"Testint * 2 >= 22 and not {TestDouble >= 55,550}", 

"Testint > 10 or TestDouble == 10 or TestFloat > 10.0", 

"TestBool i= TRUE or Testint -10 <= 10 and 2345.99 >= TestBigDeciraall" , 

The specialization of ESQuery called ESXMLQuery can be initialized from a file 
that contains a query for a Service expressed in XML: 

public ESXMLQuery {ES Connect ion core Connect ion, 
ESXMLFile xmlQueryFile) ; 



Finding Services Using XQL 



XQL can be used to find a printer described in printer^ocab. See , "IDL 
Compiler'', for more details about XML DTDs used in e-speak. 

The following XML page describes an XQL-based search that is passed to the 
ESQuery constructor: 

<?xml version="l . 0"?> 
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<ESpeak version="E- speak 1.0" operation="FindService"> 
<resource> 

<!-- The search query- -> 
<query> 

<gueryBlock> 
< WHERE > 

<l-- Begin: Specify printer Vocabulary --> 
<query> 

<queryBlock> 
< WHERE > 

<condition> 
<IN> 

<pattern> 

<Name >print ervocab< /Name> 
</pattem> 
</IN> 
</condition> 
< /WHERE > 
</queryBlock> 
</ query > 

<!-- End: Specify printer Vocabulary --> 
<!-- Begin: search conditions --> 
<condition> 

<predicate lexpr="DPI" rexpr="1400" RelOp="eq"/> 
</condition> 
<!-- End: search conditions --> 
< /WHERE > 
< /queryBlock> 
< /query > 
</ re source > 
</ESpeak> 

The Service to be discovered is specified by means of a query. An embedded query 
specifies the attribute Vocabulary in which attributes for the query conditions are 
specified. In this case, assume that this XML fragment is in a file called 
print Finder . xml. 

The query searches in the Vocabulary called printervocab for a printer whose 
DPI attribute has a value of 14 0 0. 

<?xml version= ' 1 . 0 ' ?> 

<esquery xmlns= "http : //www . e- speak . net/ Schema/E- 
speak . query , xsd" > 

<result>$serviceInfo< /result > 
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<where> 

<vocabulary name= "printervocab" src= "printervocab " / > 

<condition> 

printervocab: DPI 1400 

</condition> 
< /where > 
<preference> 
< /preference > 
<arbitration> 

<operator >f irst</operator> 

<cardinality>all</ cardinality> 
</arbitration> 
</esquery> 

There is also a constructor for ESXMLQuery that takes two ESXMLFiles as 
arguments: 

public ESXMLQuery ( ESConnection connection, ESXMLFile xmlHeader, 
ESXMLFile xmlRequest ) ; 

In the example above, in the line where printQuery is constructed, this constructor 
is used instead of the constructor that takes in a single xml file. In addition, the 
contents of the xmlHeader file look as follows: 

<?xml version= ' 1 . 0 ' ?> 

<header xmlns-"http : //www. e-speak.net/Schema/E- 
speak . header . xsd" > 

<communication> 

<to>es : //localhost : 12346/WebAccess/FindService</to> 

</coTnmunication> 
</header> 

Queries in Multiple Vocabularies 

The query can be constructed in multiple vocabularies. This feature of being able to 
specify queries in multiple vocabularies is similar to the notion of formulating 
queries in SQL that query multiple tables. Follow the steps detailed below to specify 
a query in multiple vocabulary. 

1 Specify a key for each vocabulary using the following method available in 
ESQuery: 

public void addVocabulary Key (String key, ESVocabulary vocab) ; 
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e.g., query. addVocabularyKey ("printervocab" , vocabl) ; 
query . addVocabularyKey ( "def aultvocab" , vocab2) ; 

2 Specify the constraint in "key;attr" form instead of simple "attr" form. 

string my Constraint ^ " (printerVocab : Manufacturer == 'Acme' && 
defaultvocab:Name == 'myPrinter • ) " ; 

Constraint specifies conditions that services of interest must satisfy. The lookup 
service evaluates constraint against service descriptions in the repository and 
returns a set of matching services. Sorter is applied to the resulting set of services 
to order the services. Arbitration policy is used to limit the size of the resulting set 
if the constraint evaluation results in multiple services. 



itfiN^mr. ,«A«iiten 




Figure 10 Order of Application for Service Sorting 

The above figure illustrates the order in which constraint, sorter, and arbitration are 
applied to found services. 

The query can be enhanced with a sorter. The specification of a sorter is similar to 
a notion of "order by" construct in SQL. Essentially, the user gets the finder to return 
the services using the order specified in the sorter parameter. This specification is 
done by the addSorter entry point in ESQuery. 

public void addSorter (int type. String expression); 
public void addSorter (String condition. String weight); 

The first method takes in two arguments. The first argument should be either 
ESConstants . SORTER_OPERATOR_MIN or 
ES Const ants. SORTER OPERATOR MAX. 
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They correspond to whether the results should be sorted in ascending or 
descending order respectively. The second argument is an expression involving the 
attributes. For example, if there are three attributes in a vocabulary — length, 
height, and v^idth — then we should be able to specify a sorter as follows: 

query . addSorter (ESConstants . SORTER__OPERATOR_MIN, 
«lengt]i*height*width") ; 

The second method also takes in two arguments. The first argument is the condition 
expression and the second argument is the weight expression. The condition is 
evaluated for each service and if the condition returns true, then the weight is 
added. There can be multiple such expressions. All the weights are added and the 
results are returned in the order of decreasing weights. In case of a tie, the max or 
minimum (if specified) is applied to break the tie. 

query. addSorter ("length < 5", "10"); 
query. addSorter ("weight < 10:, "2"); 

It is possible to specify an arbitration policy in the query. This is done with the 
following method. 

public void setArbitrationPolicy (int policy); 

The values allowed are ESConstants . ARBITRATI0N_P0LICY_ALL and 
ESConstants . ARBITRATION_POLICY_ANY. The first value results in all the 
services being returned and the second value results in any one the services being 
returned. 

Using Introspection 

When finding Services, sometimes the Client wants to know all the Service 
interfaces supported by the Service the Client has found. The most likely use of this 
scenario is in browsers, where the user is presented with a set of choices. This is 
possible in an e-speak environment using the introspection facility. The Client can 
get a handle to a service without knowing the interface it supports, and after getting 
the handle can query the Service to find all the Service interfaces the Service 
supports. The Client can also get a Service stub corresponding to a particular 
interface and can invoke operations on it. An example follows: 
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ESServiceFinder printFinder = new 
ESServiceFinder (coreConnection) ; 

ESService printer = printFinder . find (printQuery) ; 
ESHashMap allSupportedlnterf aceMap - 

( (ESIntrospectionlntf) printer) .getlnterf aces ( ) ; 

allSupportedlnterf aceMap contains a map of interface names and the actual 
class of the interface. The Client can find whether the Service supports a particular 
interface of interest and then get the stub corresponding to it using 

PrinterManagementlntf mg = ( (ESStubFactorylntf ) 
printer) . get ServiceStub ( ''PrinterManagementlntf " ) ; 

Another use of introspection is in the development of lightweight Clients. The 
Clients do not need to have any of the class files like the interface, stub files, and so 
forth. All these can be obtained using introspection and stub factory interfaces, and 
methods can be invoked using Java reflection. Thus introspection and stub factory 
interfaces allow building truly dynamic, lightweight, and scalable solutions. 



Service Deployer: Creating Services 

The previous section explained how a Client gains access to Services created by 
others. This section explains how Service providers create Services. As described 
earlier, Service providers perform the following sequence of operations in creating 
and managing the Service: 

1 Create a description of the Service that uses the chosen Vocabulary. 

2 Create a Service element that encapsulates the description and associates an 
implementation and a handler for the Service. 

3 Register and start the Service. 

4 If necessary, mutate the metadata of the Service. 
As with the finders, there are five kinds of elements: 
• ESContractElement 
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• ESVocabularyElement 

• ESServiceElement 

• ES Folder Element 

• ESViewElement 

A similar set of classes encapsulates the descriptions of Services: 

• ESContractDescription 

• ESVocabularyDescription 

• ESServiceDescription 

• ESViewDescription 

• ESFolderDescription 



Service Description 

Service descriptions are sets of attribute-value pairs expressed in a certain 
Vocabulary describing the Service. The Vocabulary determines the names and types 
of the attributes used in the description of the Service. For instance, a printer 
Service can be described in a Printer Vocabulary. The Printer Vocabulary in turn 
can contain attributes such as DPI that takes on an integer value, Manufacturer , 
diat takes on a string value, and Mode Iname that takes on a string value. The printer 
itself is identified by the fact that it is manufactured by a particular manufacturer, 
has a particular model name, and prints at a particular DPI value. 

Vocabularies, in turn, have to be described, and e-speak breaks the recursion using 
a Base Vocabulary that has predefined attribute properties described earlier. 

All Service Descriptions are associated with two kinds of attributes: 

• Searchable attributes— Those used in queries by Clients.These are also the 
attributes listed in each Vocabulary. 
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• Service-specific data (Data)— This data, which is stored along with the 
description of the Service, cannot be searched for, but can be accessed. This 
data can be as simple as String entries, or as complex as arbitrary byte code. For 
example, one Datum in the printer description may be the administrator's 
contact information (such as a phone number). 

In the current API, there are two ways of specifying the descriptions: 

• Using XML (This is the recommended method for specifying descriptions.) 

• Using the e-speak description of objects provided in the Client library 

Searchable Attributes 

The attributes that can be part of any Vocabulary can be in one of the 14 e- 
speakbase types: 



String 


• boolean 


byte 


• char 


short 


• int 


long 


• float 


double 


• BigDecimal 


Date 


• Time 


Timestamp 


• byteO 



The ESBaseDescription class supports the addition of attributes by the 
addAt tribute method. These calls take two parameters, the first is the name of 
the attribute, and the second parameter is the value of the parameter, 

ESContractDescription 

Contracts are also Services in the e-speak infrastructure. Contracts are typically 
described using the Base Vocabulary. Contracts encapsulate the Service IDL to 
which the Service is guaranteed to conform. 

The setlnterf aceDef inition methods set the IDL associated with the 
Contract: 
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public void setlnterfaceName (String intfName) ; 
public void setlnterfaceDefinition (String idlString) ; 
public void setlnterfaceDefinition (byte [] intfClass) ; 
public void setConversationScheme (String scheme); 
public void setTermsOf Use (String terms); 
public void setLicense (String license); 

The following code segnient explains how to create a contract using the contract 
description. 

String propertyFileName = new String {"/users/conection. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESContractDescription printContractDescription = 

new ESContractDescription 0 ; 
printContractDescription . addAttribute { ''Name" , " PrintContract" ) ; 
printContractDescription . setlnterfaceName 

( ^'printer . PrinterServicelntf " ) ; 
String idl = getlDLFromFile { ''PrinterService . esidl" ) ; 
printContractDescription. setlnterfaceDefinit ion (idl) ; 

ESContractElement printContractElement ~ 

new ESContractElement (coreConnection, 
printContractDescription) ; 

ESContract printContract = printContractElement .register {) ; 

ESVocabuiaryDescription 

This class is used to describe a new Service Vocabulary that is used in descriptions 
of other Services. As noted earlier, the printer Service is described in the Printer 
Vocabulary. 

There are two parts to describing a Vocabulary. First, because Vocabularies are 
Services that can be discovered, the attributes of the Vocabulary need to defined so 
that Clients and Service providers can discover the Vocabulary. Second, the 
properties of the Vocabulary need to be defined so that any Service that is 
registered in this Vocabulary has the same properties. These properties can also be 
used to build queries to find Services. 
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Vocabularies are somewhat analogous to a table schema in relational databases. 
The properties that make up the Vocabulary are the columns of the table, and each 
Service that is registered in the Vocabulary becomes a row in the table. In keeping 
with the database analogy, it is assumed that the names of the properties in a 
Vocabulary are case insensitive. 

Clients who are creating Vocabularies can set the name of the new Vocabulary they 
want to create using the addAttributeO method in the ESBaseDescription class. 

Just as Service descriptions contain 14 basic attributes in e-speak, the Vocabulary 
descriptions can contain properties in those 14 types: 

• String 

• boolean 

• byte 

• char 

• short 

• int 

• long 

• float 

• double 

• BigDecimal 

• Date 

• Time 

• Timestamp 

• byte [] 

Typically, Clients make a series of calls that add various named properties. For 
example, to create a description of a printer Vocabulary that has three properties 
corresponding to the manufacturer, model name, and DPI and that indicates that a 
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particular property is mandatory (meaning that any Service registered in this 
Vocabulary has to provide a value for this property), use the following code 
fragment: 

string propertyFileName = new String ( "/users/conection. prop" ) ; 
ESConnection core Connect ion = new 
ES Connect ion (propertyFileName) ; 

ESVocabularyDescription printVocabDescription = 

new ESVocabularyDescription {) ; 
printVocabDescription . addAttribute ( "'Name" , " PrintVocab" ) ; 
printVocabDescription . addStringProperty ( "Manufacturer" ) ; 
printVocabDescription . addStringProperty ( ''Modelname" ) ; 
printVocabDescription . addlntegerProperty ( "DPI" ) ; 

ESVocabularyElement printVocabElement = 

new ESVocabularyElement (coreConnection, 
printVocabDescription) ; 

ESVocabulary printVocab = printVocabElement . register () ; 

Specifying Additional Information and Essential Properties of a Vocabulary 
Property 

The example on the previous page shows registering a simple vocabulary. It can be 
seen that in the example, for each property in the vocabulary, its name and type are 
stated. For instance, addStringProperty { "Manufacturer" ) results in a 
vocabulary property whose name is "Manufacturer" and type is a String. However, 
it is possible to give more information about a vocabulary property using the 
ESProperty class, such as in the following example: 

public ESProperty (String attrName, String attrType, ESValue 
def Value, boolean isMandatory, boolean isMultiValued, int 
rangeKind, int minRange, int maxRange, int index) 

where the above terms have the following definitions: 

• attrName —the name of the property 

• attrType — the type of the property. The type could be any one of the fourteen 
data types supported. 

• defValue —the default value assigned to the property. 
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• isMandatory —specifies whether the property is an essential property or an 
optional property. If the property is an essential property, any services 
registered in the vocabulary has to specify a value for this property during 
registration. A • true ' for this parameter means that the attribute is mandatory, 
anda 'false' meansthatitisnotThis works only for an in-memory case. When 
the system is operated in JDBC mode, all the attributes are considered non- 
essential. 

• isMultiValued — specifies whether the property can have multiple values or 
not. A ' true ' for this parameter states that the property is multivalued and a 

' false ' informs the core that the property is single-valued, 

• rangeKind, minRange and tnaxRange —specify what values that the property 
can take. The rangeKind can be one of the following: ESConstant s . no_range , 
ESConstants.LEFT_RANGE, ES Const ant s . RIGHT__RANGE, and 

ESConstants . FULL RANGE . The possible values that the attribute can take is 
determined by minRange, maxRange, and rangeKind parameters. The 
rangeKind parameter determines whether the range is to the right of maxRange , 
to the left of minRange , or occupies the full range. 

• index — Specifies whether the property should be used for indexing the 
database and if so what type of indexing. This can take the following values. 
ESConstants.NO_INDEX, ESConstants .HASH_INDEX and 
ESConstants . TREE_INDEX . Hash or Tree indexing should be chosen based on 
the kind of queries that is likely to be made. If the queries are likely to be equality 
queries (" PrinterName == ' Acme ' ") , it is suggested that hash indexing is used. 
If the queries are likely to be range constraints (" Speed < lo »), then tree 
indexing gives better performance. Hash or tree indexing makes a difference 
only in in-memory mode. In JDBC mode, they are ignored and standard indexing 
provided by the databases is used. 

To create a new vocabulary property and add it to the vocabulary description, use 
code similar to this example: 

ESProperty newProp = new ESProperty ( "Location" , "String", new 
ESValue("Bldg5") , true, true, ESConstants .NO_RANGE, 0, 0, 
ESConstant s.NO_INDEX) ; 

printVocabDe script ion . addProperty (newProp) ; 
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The preceding example describes how a printer Vocabulary is defined. This 
Vocabulary description can be used by a standards body to register a Printer 
Vocabulary. Now, a printer manufacturer can choose to use this Vocabulary to 
advertise a printer with appropriate attribute values. 

For example, if a Printer Service provider were interested in offering an "Acme" 
printer as a Service, it can choose to describe the printer as follows: 

//describe printer in printervocab 

String propertyFileName = new String { "/users/connect ion. prop" ) ; 
ESConnection coreConnection = 

new ESConnection (propertyFileName) ; 
E SVo c abu 1 a ry Finder pr in tVocab Finder - 
new ESVocabularyFinder (coreConnection) ; 

ESQuery printVocabQuery = 

new ESQuery ( ''Name ' Pr intVocab "' ) ; 
ESVocabulary printerVocab - 

printVocabFinder . find (printVocabQuery) ; 

ESServiceDescription printDescription = 

new ESServiceDescription (printerVocab) ; 
printDescription . addAttribute ( ''Manufacturer" , "HP" ) ; 
printDescription . addAttribute ( "Modelname" , " LP 5" ) ; 
printDescription. addAttribute ("DPI", (int) 1400) ; 

Multi-Valued Attributes 

One of the new features in version 3.0 is support for multi-valued attributes in in- 
memory systems. This support allows the user to specify multiple values for a single 
service attribute. The following example deals with a printer that will accept several 
types of documents, including .pdf, .ppt, and .doc. The following conunands set the 
printer's DocumentType attribute to accept multiple values: 

ESAttribute multiAttr = new ESAttribute ( "DocumentType" , new 

ESValueC'DOC") ) ; 

// add additional values 

Object [] vals = new Object [3]; 

vals[0] - "PDF"; 

vals[l] = "PPT"; 
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vals[2] - "XLS"; 
multiAttr .addValues (vals) ; 
description. addAttribute (multiAttr) ; 

If the client uses any of these values to do a lookup, the service v^ill be found by the 
client. For example: 

finder- find {vocab, new ESQuery ( "Document Type 'DOC*")); 
f inder .find{vocab, new ESQuery ( "Document Type == 'XLS'")); 
finder. find (vocab, new ESQuery ("Document Type == 'PPT'")); 

All these queries will result in the service being found. This powerful feature can be 
used in cases where a service attribute may have more than one value as in the 
previous example. 

XML Descriptions of Services 

So far, APIs have been used to create and manage descriptions in Java. In addition 
to these APIs, J-ESI supports XML descriptions of Vocabularies and Service 

s using the constructors described here. XML is the preferred mode for describing 
Vocabularies and Services. Typically, XML is used for data descriptions passed as 
parameters to the description constructors. 

XML Vocabulary Description 

The ESVocabularyDescription class has a constructor that takes in an 
ESXMLFile describing the Vocabulary encapsulated in an XML page: 

public ESVocabulary (ESXMLFile xml_stream, ESConnection conn) / 

This example creates a new Vocabulary with three attribute properties: 
Manufacturer, Modelname, and DPI: 

<?xml version="l . 0"?> 

<ESpeak version="E- speak 2.0" operation=" Great eVocab" 
xmlns="http: //localhost/e:/Esxml/Scheinas/espeak,xsd"> 
<resource xTnlns=""> 

<resourceDes xmlns=""> 
<pattern> 

<Name xmlns=""> 
printervocab 
</Name> 
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<Type> 

Vocabulary 
</Type> 
</pattern> 
</resourceDes> 
<resourceData xmlns= " " > 

<attrGroup name="my printer Vocabulary" xmlns=""> 
<attrDecl xmlns="" name= "Manufacturer" required="no" > 
<datatypeRef xmlns="" name="string"/> 
</attrDecl> 

<attrDecl xTnlns="" name =" Model name" required="no" > 

<datatypeRef xmlns="" name= " string" /> 
</attrDecl> 

<attrDecl xmlns="" name="DPI" reguired="no" > 
<datatypeRef xmlns="" name= " integer" > 
</datatypeRef > 
</attrDecl> 
</attrGroup> 
</resourceData> 
</resource> 
</ESpeak> 

All XML requests in e-speak have E-speak as the root element, which specifies the 
version information as well as the intended operation for the Services described in 
the request. As noted earlier, two aspects are required to describe Vocabularies. 

First, how CUents can find the Vocabulary has to be described. It is assumed that 
the Vocabularies are themselves defined in the default Vocabulary that allows 
specifying, among other things, the name and type of Service. In the preceding XML 
description, the element resourceDes specifies the Name of this Vocabulary to be 
print ervocab. Because this is a Vocabulary, its Type is Vocabulary. 

Second, the properties of the Vocabulary must be specified. The properties that 
make up the printer Vocabulary are contained in an attrGroup element The 
attrGroup element contains a list of attrDecl elements, each describing the 
specifics of an attribute property, including its name and data type. 

The XML file defines a Printer Vocabulary that has three properties: 

1 Manufacturer 

2 Modelname 

3 DPI. 
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As with queries, J-ESI 3.0 supports a new XML format for creating vocabularies. The 
new format involves constructing ESVocabularyDescription with two ESXMLFile 
arguments 

public ESVocabularyDescription (ESConnection connection, 
ESXMLFile xmlHeader, ESXMLFile xmlRequest) 

The contents of xmlHeader looks as follows; 

<?xml version='1.0'?> 

<header xmlns= "ht tp : / /www . e - speak . ne t /Schenia/E - 
speak . header . xsd" > 

<commmication> 

<to>es : / /localhost : 12346/WebAccess/CreateVocab</to> 

</communication> 
</header> 



The contents of xmlRequest looks as follows: 

<?xml version= ' 1 . 0 ' ?> 

<resource xmlns= "http : //www . e-speak . net/Schema/E- speak . register . xsd" > 
<resourceDes> 

< vocabul ary >ht tp : / /www . e - speak . net /Schema/ E - speak . ba se . xsd< / 
vocabulary > 

<attr name =" Name " > 

<value>printervocab< /value > 
</attr> 

<attr name="Type"> 

< value >VGcabulary< /value > 
</attr> 
</resourceDes> 

ottrGroup name^ "print ervocab" xmlns="http : / /www. e-speak.net/Schema/ 
E - speak . vocab . xs d " > 

<attrDecl name= "Model" required=" true"> 

<datatypeRef name= "String" /> 
< /attrDecl> 

<attrDecl name="DPI" required="true"> 

<datatypeRef name= "String" /> 
</attrDecl> 

<attrDecl name= "Manufacturer" required="true" > 

<datatypeRef name= "String" / > 
</attrDecl> 
</attrGroup> 
</resource> 
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XML Service Description 

The ESServiceDescript ion class has a constructor that takes in an ESXML file 
describing the Vocabulary encapsulated in an XML page, as follows: 

public ESServiceDescription(ESXMLFile xmlDescriptionFile , 
ESConnection coreConnection) ; 

This is the recommended mode of creating and registering Services for 
compatibility with existing or emerging Vocabularies. The following example 
registers a new Service using the Vocabulary just created: 

<?xml version="1.0"?> 

<ESpeak version="E-Speak l.Obeta" operation="RegisterService" 
xmlns= "http : //localhost/e : /Esxml/Schemas/espeak . xsd" > 
< resource > 
<resourceDes xmlns-"" name= " Printer" > 
<!-- Specify printer Vocabulary --> 
<query xmlns " " > 

<queryBlock xmlns=""> 
<WHERE xmlns=""> 

<i-- absence of query implies Base Vocabulary --> 
<condition xmlns=""> 
<IN xmlns =" " > 

<pattern xmlns=""> 
<Name 

xmlns " >printervocab</Name> 
<Type 

xmlns = " " >Vocabulary< /Type> 
</pattern> 
</IN> 
</condition> 
</WHERE> 
< /queryBlock> 
</query> 

<!-- Begin: attributes 

<attrSet xmlns=""> 

<i-- End: Use printerVocabulary --> 

<attr xmlns="" name= "Manufacturer" required="true" > 

<value xmlns=" ">HP</value> 
</attr> 

<attr xmlns="" name="Modelname" required^ " false "> 

<value xmlns="">LP 5</value> 
</attr> 
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<attr xmlns="" naTne="DPI"> 

<value xTnlns="">1400</value> 
</attr> 

<\" End: attributes --> 
</attrSet> 
< / re sourceDe s > 
</resource> 
</ESpeak> 

In the preceding example, XML has been used to describe a specific printer. The 
XML description has two parts. The first part of the XML document, the Vocabulary 
in which the rest of the description is to be interpreted, is specified. For example, 
the query specifies that the following description is in a Vocabulary whose name is 
printervocab: 

<?xml version="l . 0"?> 

<ESpeak version="E-Speak l.Obeta" operation="RegisterService" 
xmlns="http://localhost/e:/Esxml/Schemas/espeak.xsd"> 
<resource> 
<resourceDes xmlns="" name=" Printer" > 
<i-- Specify printer Vocabulary --> 
< query xmlns= " " > 

<gueryBlock xmlns=" " > 

< WHERE xmlns=""> 
< condition xmlns=" " > 

<IN xmlns=""> 

<pattern xmlns=""> 

<Name >pr intervocab< /Name > 
< Type >Vocabul ary < / Type > 
</pattern> 
</IN> 
</condition> 
</ WHERE > 
</queryBlock> 
< /query > 

In the second part, the element attrSet actually contains the set of attribute value 
pairs that describe the particular Service in question. The following example 
describes a printer whose Manufacturer is HP, whose Model name is LP 5 , and 
whose DPI is 1400: 

<?XTnl version= ' 1 . 0 ' ?> 

<resource xmlns^"http : //www. e- speak. net/Schema/E- 
speak . register . xsd" > 
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<resourceSpec> 

< locator > 
ht tp : / /www . hp , com 

</locator> 
< /resourceSpeo 
<resourceDes> 

<vocabulary> 
print ervocab 
</vocabulary> 

<attr naine= "Manufacturer" > 

<value>HP< /value> 
</attr> 

<attr name="Modelname"> 

<value>LP 5</value> 
</attr> 

<attr name="DPI"> 

< value >1400</va lue > 
</attr> 
</resourceDes> 
</resource> 

J-ESI does support the older XML schemas for registering services, but they should 
be treated like deprecated schemas and clients are encouraged to move to the 
newer schemas. The header for the service description creation looks as follows: 

<?xTnl version= ' 1 . 0 ' ?> 

<header xmlns= "http : //www . e- speak .net/ Schema/E- 
speak . header . xsd" > 
<communication> 

<to>es ://localhost : 12346/WebAccess/RegisterService</to> 

< context > 

<i-- session token is inserted by the requesting appl . --> 
</ context > 
</communication> 
</header> 

The ESServiceDescription constructor that uses the new XML entry points looks as 
follows: 

public ESServiceDescription (ESConnection connection, 
ESXMLFile xmlHeader, 
ESXMLFile xmlRecfuest ) 



74 



Developer Release X.03.03.00, September 2000 



Basic Services 



Service Description 



Example: Creating a Printer Description 

The following example shows how to make an XML description of a printer 
registered in the e-speak Core, This code assumes that a printervocab 
Vocabulary is found in the registry: 

String propertyFileName = new String ("/users/connect ion. prop" ) ; 
ESConnection core Connect ion = new 
ESConnection (propertyFileName) ; 
ESXMLFile xmlDescriptionFile = 
new ESXMLFile CVusers/printer.xml") ; 

ESServiceDescription printDescription = 
new ESServiceDescription (xmlDescriptionFile, 
coreConnection) ; 

where printer . xml is the XML file that has the contents in the last example. This 
is much more succinct than explicitly adding all the properties by hand. A typical 
usage scenario reads a list of products described in a merchant's catalogs, 
described in XML, to be read in and automatically registered as Services in e-speak. 

Now that various methods have been presented for describing Services, the next 
section describes other operations that Service providers have to perform to make 
their Service available to other Clients. 

Registering and Starting Services 

Typically, Service providers have to associate an actual implementation with their 
Service, register their Service, and start a handler that will handle requests directed 
to this Service. J-ESI provides an abstraction of a Service element represented by 
the ESServiceElement class for performing these operations. 

Consider the steps required to register a printer Service (PrinterServicelmpl) 
that implements the PrinterServiceInt f . The following code fragment creates 
a Service described in the default Vocabulary with the name MyPr inter, registers 
it, and starts a thread that can process requests to the Service. The register ( ) 
call puts the description of the Service into the e-speak Repository so that other 
Clients can discover it. The start { ) call starts a thread that processes requests to 
this Service. 

string propertyFileName = new String { 'V users/connect ion .prop" ) ; 
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ESConnection coreConnection = new 
ESConnection { proper tyFileName) ; 
ESXMLFile xmlDescriptionFile = 

new ESXMLFile ('Vusers/printer.xml") ; 
ESServiceDescription printDescription = 

new ESServiceDescription (xmlDescriptionFile, 
coreConnection) ; 
ESServiceElement printElement = 

new ESServiceElement (coreConnection, printDescription) ; 
printElement . setlmplementation (new PrinterServicelmpl () ) ; 
ESAccessor printAccessor = printElement . register () ; 
printElement . start ( ) ; 

In this example, a single thread is started that handles the requests to the Service, 
All requests destined to this Service are dispatched to an instance of the 
PrinterServicelmpl object. 

There are situations where Clients may want to associate multiple Services with the 
same thread, or have multiple threads for the same Service. The current Client 
library allows Service providers to control the number of threads through the 
notion of a Service handler, represented by the ESServiceHandler class. 

Every connection with the e-speak Core has a default Service handler 
associated with it. This default Service handler can be retrieved using the 
getDef aultServiceHandler call in the connection, as shown by the following 
code fragment: 

string propertyFileName = new String ( "/users/connection. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESServiceHandler def aultHandler - 
coreConnection . getDef aultServiceHandler ( ) ; 

In essence, each Service handler encapsulates a channel of communication through 
which messages are received. A single Service handler can serve as a channel for 
getting messages to multiple Services. Each Service handler also has control over 
the number of threads that process the messages that are delivered on the 
communication channel. 

In the following example, a print server maintains a message queue for multiple 
printers. This is made possible by using the same handler for all the printers. The 
print server has 32 threads that process the requests of the Clients. The following 
code sample shows how this is accomplished: 
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string propertyFileName = new String ( 'Vusers/connect ion .prop" ) ; 
ES Connect ion coreConnection = new 
ES Connect ion (propertyFileName) ; 
ESServiceHandler printHandler = 

new ESServiceHandler (coreConnection) ; 
printHandler . setNumThreads (32) ; 

ESServiceDescription printDescriptionl = 

new ESServiceDescription 0 ; 
printDescriptionl . addAttribute ( '"Name" , " Printer 1" ) ; 
ESServiceElement printElementl ~ new 

ESServiceElement (coreConnection, printDescriptionl) ; 
printElementl . setlmplementation (new PrinterServicelmpl () ) ; 
printElementl . setHandler (printHandler) ; 
ESAccessor printAccessorl = printElementl , register {) ; 
printElementl . start ( ) ; 

ESServiceDescription printDescription2 = 

new ESServiceDescription () ; 
pr intDescript ion2 . addAttribute ( ''Name" , " Printer 2 " ) ; 
ESServiceElement printElement2 = 

new ESServiceElement (coreConnection, printDescription2) ; 
printElement2 . setlmplementation (new PrinterServicelmpl { ) ) ; 
printElement2 . setHandler (printHandler) ; 
ESAccessor printAccessor2 = printElement2 . register () ; 
printElement2 . start ( ) ; 

The Service elements for each printer share the same handler. This way, there is a 
single queue for requests for both printers, and there are 32 threads that handle 
requests to the printers. 

Service-Specific Data 

As described earlier, Service-specific data is arbitrary data that can be associated 
with Services. Service-specific data comes in two forms: public and private. 

PublicData is data that can be accessed by any Client that can find the Service. 

PrivateData is data that is sent back to the Service handler along with each request 
to the Service. For example, this data can be used by the Service handler to 
distinguish among various Services that share this handler. 
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The following two API calls allow Clients to add public and private data to the 
descriptions: 

public void addPublicData (String dataName, byte [] data) ; 
This API call adds public Service-specific data to the Service element 

public void addPrivateData (String dataName, byte [] data) ; 
This API call adds private Service-specific data to the Service element. 

For example, in a file system implementation, where the file store and the files 
themselves are Services, the file store may choose to identify the files it creates 
using private Data. This allows the file store to be very generic because it uses a 
flexible implementation for storing the bytes that make up a file. 

If the bytes are stored on the local disk directly, the file store can use the private 
Data to keep track of the directory path on the local disk for the file. If the file store 
instead stores the bytes making up a file in a database table, the information needed 
to access the row in the table where the bytes of the files are stored is in the private 
Data. 

This allows the file handler to determine where the bytes of the file are stored when 
a request for this file is received. The names for the data elements are selected by 
the creator of the Service based on need. Service creators can choose to associate 
multiple Data elements with every Service they create. 

Creating Services Described in Multiple Vocabularies 

In the current version of J-ESI, services can be advertised in multiple vocabularies. 
In essence, the ESServiceElement can be constructed with an array of service 
descriptions, each of which describes the service in one vocabulary. For instance, 
suppose that a printer service provider wanted to advertise the printer in two 
vocabularies. Suppose one of the vocabularies enabled the service provider to 
advertise the speed of the printer and the second allowed the service provider to 
advertise the printer quality measured in terms of the dots per inch (DPI) . 
Furthermore, the properties that one can add to a vocabulary can be flagged as 
primary key properties so that the e-speak repository can build indices using such 
attributes. This allows the searches that use these properties to be quite efficient. 

ESServiceDescription sd[] = new ESServiceDescription [2] ; 
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try{ 

ESConnection connection = new ESConnection (^'f ile .pr'M ; 

//Creating the vocabulary 

ESVocabularyDescription vocabDesc ~ new 
ESVocabularyDescriptionO ; 

ESVocabularyDescription vocabDescl = new 
ESVocabularyDescriptionO ; 

//Setting the vocabulary name 
vocabDesc , addAttribute ( "Name" , "vocab" ) ; 
vocabDescl. addAttribute( "Name", "vocabl") ; 

//Adding vocabulary properties 

vocabDesc . addStringProperty ( "printerSpeed" ) ; 

vocabDescl . addStringProperty ( "printerDPI " ) ; 

//Registering the vocabulary 

ESVocabularyElement vocabElem = new 
ESVocabularyElement (connection, vocabDesc) ; 

ESVocabularyElement vocabEleml = new 
ESVocabularyElement (connection, vocabDescl) ; 

ESVocabulary vocab = vocabElem. register {) ; 

ESVocabulary vocabl = vocabEleml . register () ; 

ESServiceDescription sd = new ESServiceDescription [2] ; 

//Creating the service description 

sd[0] = new ESServiceDescription (vocab) ; 

sd[l] - new ESServiceDescription (vocabl) ; 

//Setting the service name 
sd[0] .addAttribute ("Name", "myPrinter") ; 
sd[0] .addAttribute {^^printerSpeed" , "10") ; 
sd[l] .addAttribute ("Name" , "myPrinter") ; 
sd[l] .addAttribute ("printerDPI", "1000") ; 
//Create the service element 

ESServiceElement se = new ESServiceElement (connection, 
sd) ; 



Restarting Existing Services 

Just as Service providers can start new Services, J-ESI allows Service providers to 
restart existing Services. Clients may want to restart Services in order to resume a 
Service after recovering from a Service shutdown or outage. Clients can restart 
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Services in three ways: (i) They can construct a Service element from the 
description and call res tart 0 on the element, (ii) they can store away the 
accessor for the service in a persistent folder and use the accessor to restart the 
service, or (iii) they can store away the accessor of the handler in a persistent folder 
and use that accessor to restart the service. Modes (ii) and (iii) are discussed in the 
next chapter in the section on folders. 

The element attempts to find a Service whose description matches the description 
currently provided in the element. If such a Service is found, it activates that Service 
so that requests to that Service are now handled. However, if no such Service is 
found, an exception occurs and the Client is expected to catch the exception and 
then register and start the Service. 

However, the recommended mode for restarting Services is with the use of Folders. 
The Client is expected to have created a local name for the Service in their folder 
hierarchy. See "Managing Bindings Using Folders" on page 91 to determine how to 
restart Services using the binding. 

The following example shows the typical use of the restart method without the use 
of Folders: 

public static void main (String [] args) 

{ 

try 

{ 

String propertyFileName - 

new String CV Risers /connect ion. prop") ; 
ES Connect ion coreConnection = 

new ESConnect ion (propertyFileName) ; 
ESXMLFile xmlDescriptionFile = 

new ESXMLFile (*Vusers /printer. xml") ; 
ESServiceDescription printDescription = 

new ESServiceDescription 

(xmlDescriptionFile, coreConnection) ; 
ESServiceElement printElement = 

new ESServiceElement (coreConnection, printDescription) ; 
printElement . setlmplementation (new PrinterServicelmpl () ) ; 
ESServiceHandler printHandler = 

new ESServiceHandler (coreConnection) ; 
printHandler . setNumThreads (2 ) ; 
printElement . setHandler (printHandler) ; 
try 
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{ 

printElement. restart 0 ; 

System. out ,println("XMLPrintServer re-started") ; 

} 

catch (ESLibRuntimeException ere) 

{ 

printElement .register 0 ; 
printElement . start { ) ; 

System. out . print In ("XMLPrintServer started") ; 

} 

} 

catch (Exception e) 

{ 

// handle the exception 

} 

} 



Registering Vocabularies and Contracts 

Vocabularies and Contracts are themselves Services that are registered with the e- 
speak infrastructure. However, the Service provider for Vocabularies and Contracts 
is the e-speak Core itself. Because of this, Clients who create Vocabularies only 
register them, and do not start a thread in order to serve requests to the Vocabulary 
or Contract. 

The classes that allow Clients to register Vocabularies and Contracts are 
ESVocabularyElement and ESContractElement, respectively. The 
following code fragment registers a printer Vocabulary that has three properties: 
DPI, 

Manufacturer, and Modelname: 

public class VocabularyCreator 

{ 

public static void main (String [] argv) 

{ 

try 

{ 

String propertyFileName = 

new String ( 'Vusers/ connect ion. prop" ) ; 
ESConnection coreConnection = 
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new ESConnection (propertyFileName) ; 

ESVocabularyDescription printVocabDescription = 

new ESVocabularyDescription 0 ; 
printVocabDescription . addAttribute 

( "Name" , "printervocab" ) / 
printVocabDescription . addlntegerProperty ( "DPI " ) ; 
printVocabDescription . addStringProperty ( "Manufacturer" ) ; 
printVocabDescription . addStringProperty ( "Modelname " ) ; 

ESVocabularyElement printVocabElement = 
new ESVocabularyElement (coreConnection, 

printVocabDescription) ; 
ESVocabulary printVocab = printVocabElement .register {) ; 

Property [] propertyList = printVocab .getProperties () ; 
for (int i = 0; i < propertyList . length; i-f+) 

{ 

System. out .print In (propertyList [i] .getPropertyName ( ) ) ; 

} 
} 

catch (Exception e) 

{ 

// handle the exception 

} 

} 

} 

Creating Contracts is very similar to the creation of Vocabularies. The following 
code fragment shows the creation of a simple Contract: 

public class ContractCreator 
{ 

public static void main (String [] argv) 

{ 

try 

{ 

String propertyFileName = 

new String {"/users/connect ion. prop") ; 

ESConnection coreConnection = 

new ESConnection (propertyFileName) ; 
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ESContractDescription printContractDescription = 

new ESContractDescription 0 ; 
printContractDescription . addAttribute 

("Name" , "PrintContract " ) ; 

String printlDL = getlDLFromFile ( ) ; 
printContractDescription . setlnterf aceDef init ion (printlDL) ; 

ESContractElement printContractElement = 
new ESContractElement (coreConnection, 
printContractDescription) ; 
ESContract printContract = printContractElement . register {) ; 

String receivedPrintlDL = 
printContract . getlnterf aceDef inition { ) ; 

System, out .println (receivedPrintlDL) ; 

} 

catch (Exception e) 

{ 

// handle the exception 

} 
} 
} 

On registering a Vocabulary or Contract, the Clients receive a stub to the created 
Vocabulary or Contract. This is in contrast to other Services that the Client creates, 
where they receive an accessor to the Service that they create. (ESAccessor is 
explained in detail in the later sections) This is because the Client that is registering 
the Vocabulary or Contract is not the handler for that Vocabulary or Contract. 

A Bank Service Example 

The following example is a complete Bank Service example that makes use of many 
of the concepts introduced in this chapter. Figure 11 shows the relationship 
between a Bank Service, a Bank Service Contract, and the Bank Service Vocabulary. 
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Typically, the Bank Vocabulary, Bank Contract, and Bank Service are not defined 
by the same programmer; however, for the sake of simplicity in this example, we 
can assume that they are defined by the same person. 




The following example lists the sequence of actions performed by a Bank Service 
(assuming the Vocabulary, Contract, and Service are all defined by the same piece 
of code) : 

string props rtyFileName = new String ("/users/connect ion. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESContractDescription bankContractDescription = 

new ESContractDescription () ; 
bankContractDescription . 

addAttribute { ^Narne" , "BankContract" ) ; 
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ESContractElement bankCon tract Element = 
new ESContractElement (coreConnection, 
bankContractDescription) ; 
ESContract bankContract = bankContractElement . register () ; 

ESXMLFile xmlDescriptionFile = 

new ESXMLFile ( "/users/bankVocab .xml" ) ; 
ESVocabularyDescription bankVocabDe script ion = new 
ESVocabularyDescript ion (xmlDescriptionFile , 
coreConnection) ; 
ESVocabularyElement bankVocabElement = new 
ESVocabularyElement ( coreConnection, 
bankVocabDescription) ; 
ESVocabulary bankVocab = bankVocabElement .register () ; 



xmlDescriptionFile = 

new ESXMLFile { "/users/bank. xml" ) ; 
ESServiceDescription bankDescription = 

new ESServiceDescription (xmlDescriptionFile, 
coreConnection) ; 
bankDescription , setContract (bankContract) ; 

ESServiceElement bankElement = 

new ESServiceElement (coreConnection, bankDescription) ; 
bankElement .setlmplementation (new BankServicelmpl ( ) ) ; 
ESAccessor bankAccessor = bankElement . register () ; 
bankElement . start { ) ; 

The following example shows the contents of the bankVocab . xml file that is used 
to describe the Vocabulary: 

<?xml version="l . 0"?> 

<ESpeak version="E-speak 1.0" operation="CreateVocab" > 
<resource> 

<!-- Begin: Specify the Vocabulary description --> 
<resourceDes> 
<attrSet> 

<attr name =" Name "> 

<value >bankvocab< /value > 
</attr> 
</attrSet> 
</resourceDes> 

<!-- End: Specify the Vocabulary description --> 
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<resourceData> 

<!-- Begin: Specify the attribute property set 
<attrGroup naTne="Bank Vocabulary" > 
<attrDecl name Name " > 

<datatypeRef name=" string" / > 
</attrDecl> 

<attrDecl name="createAccount" > 

<dat atypeRe f name=" string" / > 
</attrDecl> 

<attrDecl name="tradeStock"> 

<datatypeRef name=" string" /> 
</attrDecl> 
</attrGroup> 

<•-- End: Specify the attribute property set --> 
</ resourceData> 
</resource> 
</Espeak:> 

The following example lists the contents of the bank . xml file that is used to 
describe the particular Bank Service: 

<?xml version="l. 0" ?> 

<ESpeak version="E-Speak 1.0" operation="RegisterService"> 
<resource> 

<resourceDes name="Bank Description" > 

<!-- Begin: Specify bank Vocabulary in a query- -> 
<query> 

<queryBlock> 
<WHERE> 

<condition> 
<IN> 

<pattern> 

< Name >bank vo c ab < / Name > 
</pattem> 
</IN> 
</condition> 
</WHERE> 
</gueryBlock> 
</query> 

<!-- End: Specify bankVocabulary --> 
<!-- Begin: the attribute list --> 
<attrSet> 

<l-- End: Use bank Vocabulary --> 

<attr name="Name"> 
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< va lue >Acme < / va lue > 
</attr> 

<attr name="createAccoiint" > 

<value type=" string" >" Acme l"</value> 
</attr> 

<attr naTne="tradeStock"> 

<value type=" string" >"hwp" < /value > 
</attr> 
</attrSet> 

<[-- End: the attribute list --> 
< /resourceDes > 
</resource> 
</ESpeak> 



Accessing Descriptions: ESAccessor 

ESAccessor is a reference to a Service with which the user can do the following. 

• Obtain or change the attributes of a Service 

• Send messages to the Service (More details are in Appendix B) 

Typically, a Client finds a Service that matches some desired attributes, but after 
finding tiie Service, the Client may be interested in checking the values of other 
attributes as well 

For example, a Client may find a list of printers meeting a certain DPI value, but 
after finding this list, the Client may want to determine the manufacturer name 
before proceeding ftirther. In such situations, the Client can get the accessor for 
each Service and query the accessor for the manufacturer attribute's value. 

Similarly, an administrator who manages the printer may want to mutate one of the 
searchable attributes or add new Data to reflect some upgrade to the printer. In this 
case, the ESAccessor is used to mutate the Service description as well For 
example: 

string propertyFileName = new String ('Vusers/connect ion. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESXMLFile xmlDescriptionFile = 
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new ESXMLFile { "/users/printerQuery.xml" ) ; 
ESXMLQuery printQuery = new ESXMLQuery (coreConnection, 

xmlDescriptionFile) ; 
ESServiceFinder printFinder = new 
ESServiceFinder (coreConnection) ; 

ESService printService = printFinder . find (printQuery) ; 
ESAccessor printAccessor = 

( (ESAccessorHandle) printService) .getAccessor { ) ; 

On the Service provider side, when a Service is registered, an accessor is returned 
as a result of doing the register call. For example: 

string propertyFileName = new String ( "/users/connection. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESServiceDescription printDescription ^ 

new ESServiceDescription (print Vocab) ; 
printDescription. addAttribute("Modelname" , "HPIOOO") ; 
ESServiceElement printElement = 

new ESServiceElement (coreConnection, printDescription) ; 
printElement . setlmplementation (new PrinterServicelmpl () ) ; 
ESAccessor printAccessor - printElement . register () ; 
printElement . start { ) ; 

The Service provider can now use the accessor to access and mutate the description 
of the Service. 

Consider a printer Client who, after finding a printer with DPI == 1400, decides 
to list all the attributes of the printer, perhaps in an effort to find out its 
manufacturer, speed, and so on.: 

string propertyFileName = new String { 'Vusers/connec tion. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESServiceFinder printFinder = 
new ESServiceFinder (coreConnection) ; 

ESQuery printQuery = new ESQuery (printervocab) ; 
printQuery. addConstraint {''DPI==1400" ) ; 
ESService printService = printFinder . find (printQuery) ; 
ESAccessor printAccessor = 

( (ESAccessorHandle) printService) .getAcessor ( ) ; 
System. out .print In ( "Attributes of this printer are:\n"); 
ESAttribute [] attrList =printAccessor.getAt tributes () ; 
for(int i=0; i<attrList . length; i++) 
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{ 

System. out .println{attrList [i] .toStringO) ; 

} 

A Service provider who has created a Service or a Client and who has the 
appropriate permissions can change the attributes of the Services. For example, if 
the administrator upgrades the printer to the latest model that supports a higher 
DPI, the administrator can update the description of the printer with the new values 
for the attributes as follows: 

// code to find print service from above 

String propertyFileName = new String ( 'Vusers/connect ion .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESVocabularyFinder printVocabFinder = 

new ESVocabularyFinder (coreConnection) ; 
ESQuery printVocabQuery = 

new ESQuery ( "Name ' print e rvoc ab "') ; 
ESVocabulary printVocab = 
printVocabFinder . find (printVocabQuery) ; 

ESQuery printQuery = new ESQuery ( ''Manufacturer == 'HP'"); 
ESService printService = printFinder. find (printQuery) ; 
ESAccessor printAccessor = 

( (ESAccessorHandle) printService) .getAccessor () ; 

ESAttribute attrl = new ESAttribute ( ''Manufacturer" ) ; 
attrl . setValue ( ''HP" ) ; 

ESAttribute attr2 = new ESAttribute ( "DPI" ) ; 
attrl . setValue ( (int) 1400) ; 

printAccessor. setAttribute (attrl, printVocab) ; 
printAccessor . setAttribute ( attr2 , printVocab) ; 

The ESAccessor class also has other methods that can be used to mutate the 
metadata of services. Examples of such methods are the following. Note that 
though some of these signatures refer to ESBaseDescription, in practice, these 
return values or arguments to these functions are instances of 
ESVocabularyDescription, ESContractDescription. ESViewDescription. 
ESServiceDescription, etc. 

public void setDescr ipt ions (ESBaseDescript ions [] desc) ; 
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public void setDescription (ESBaseDescription desc) ; 
public void setAttribute (ESAttribute attr, ESVocabulary vocab) ; 
public void setAttributes (ESAttribute [] attrs, ESVocabulary 
vocab) ; 

public ESBaseDescription [] getDescriptions ( } ; 

public ESBaseDescription getDescription {) ; 

public ESAttribute getAttribute (String name, ESVocabulary 

vocab) ; 

public ESAttribute [] getAttributes (String name, ESVocabulary 
vocab) ; 
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The previous chapters described the programming model, and how e-speak Chents 
and Services interact. In addition to support for these basic functions, J-ESI 
supports extended Services that enable support for persistent bindings, Event- 
based interaction semantics, and loosely coupled distributed Communities. This 
chapter shows how these extended Services can be used to create sophisticated 
Service interactions. 

The chapter is divided into the following sections: 

• Managing Bindings Using Folders 

• Repository Views 

• Categories 

• Communities 

• Security 

• Events 



Managing Bindings Using Folders 

One of the main reasons why e-speak can support loosely coupled distributed 
Services is that it does not rely on global naming. In many traditional distributed 
systems, the distribution is possible because Clients know the name of the Service 
providers and they use the name to access the Service. 
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In e-speak, on the other hand, there are no global names. Clients can make up names 
for the Services they find or create, and that name is independent of the name that 
another Client uses for the same Service. 

For instance, one Client may refer to a Printer Service as "Marketing Printer,** while 
another Client may refer to the same Printer Service as "Engineering Printer/ This 
allows Services to be migrated or upgraded, without having to change the Client- 
side programs that use these Services. Figure 12 illustrates the naming process in e- 
speak. 



Figure 1 2 Example of folder names using e-speak 

In J-ESI, Clients manage their local name spaces using folders. Folders are 
analogous to directories in traditional file systems. Clients can create bindings 
between the names and Services they find and then put the bindings in a folder. 

Essentially, folders enable Clients to build a local hierarchical name space. Every 
user account in an e-speak Core has a folder that is its root (typically denoted by /). 
Clients can get at the root folder in their session by invoking the getRoot Folder 
method in ESConnection. For example: 

string propertyFileName = new String ( ^Vusers/connect ion .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESFolder myRoot = coreConnection . getRootFolder () ; 
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Creating Folders 

Folders created by Clients are either persistent or transient. A transient folder is a 
folder that does not survive beyond the lifetime of the connection in which it is 
created. A persistent folder, on the other hand, can survive beyond the lifetime of 
the connection in which it is created. If the Core is backed up in a database, 
persistent folders also survive Core reboots. This is because, although the folders 
are a Client-side abstraction, their state is maintained in the e-speak Core. 

Creating Transient Folders 

Currendy, Clients can create transient or persistent folder hierarchies under the 
root folder. To create a transient folder hierarchy, they create a subfolder of the 
root folder that is transient. For example, to create a transient folder under the root 
folder called bookmarks, use the following constructor of ESFolder: 

string propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESFolder bookMarkFolder = new ESFolder (coreConnection, 
"bookmarks" ) ; 

This call creates a transient folder under the root folder called /bookmarks. The 
folder constructor is used to create subfolders of the root folder, while the 
createSubFolder method is used to create subfolders of all non-root folders. 

Creating Persistent Folders 

The above ESFolder constructor cannot be used to create persistent folders. To 
create a persistent folder called /myServices under the root folder, the following 
call is used: 

string propertyFileName ^ new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESFolder ownFolder = new ESFolder (coreConnection, "myServices", 
true) ; 
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By default a root folder is persistent. Hence, the user invokes the 
createSubFolder method on the root folder to create persistent folders. 
Because the folder /myServices is a persistent folder, any subfolder of / 
myServices is also persistent. 

As in most operating systems, there is the idea of a current folder in J-ESI. Clients 
can get their current folder through the Service context, as shown by the following 
code fragment: 

string propertyFileName = new String {'Vusers/connect ion. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESServiceContext connect Context = 

coreConnection.getServiceContext {) ; 
ESFolder currentFolder ^ connect Context .getCurrentFolder {) ; 

When a new connection is created, the name of the home folder is read from the 
properties file that is passed to the constructor of ESConnection. The value of the 
property named homef older in the properties file is used as the name of the home 
folder. If no properties file is passed to the constructor of ESConnection, the 
default home folder is /home. The home folder can be obtained as follows: 

string propertyFileName = new String ( 'Vusers/connect ion. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESFolder iiomeFolder = coreConnection.getHomeFolder () ; 

The properties of the current folder that the Client is located in are important. If a 
Client creates Services while in a persistent folder, the Service is created as a 
persistent Service. This means that the description of the Service is registered with 
the e-speak Core even if the handler of the Service disconnects from the e-speak 
Core. 

Naming Found Services 

Clients typically create folders to manage name bindings on Services they have 
discovered or created. For example, an administrator may add bindings to 
discovered print Services in a persistent folder (such as /home/services / 
printers). Because the bindings are stored in a persistent folder, anytime the 
administrator reconnects, they continue to have access to previously discovered 
printers by simply looking into die persistent /home/printers folder. 
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The following code fragment shows the creation of a subfolder ' printers ' of the 
Client's home folder (/home/services). After printers is created, the Client 
finds a printer and places a name binding for it in this folder. 

string propertyFileName = new String ( "/users/connection. prop" ) ; 
ESConnection coreConnection = new 
ESConnect ion (propertyFileName) ; 
ESServiceContext connectContext ^ 

coreConnection.getServiceContext 0 ; 
ESFolder currentFolder = connectContext .getCurrentFolder () ; 
// The current folder is assumed to be /home/ services . 
// This can be set in the properties file 
ESFolder newFolder = null; 
try { 

newFolder = currentFolder , getSubFolder { "printers " ) ; 
catch (InvalidNameException ine) { 

^newFolder = currentFolder . createSubFolder { "printers" } ; 

connectContext , setCurrentFolder (newFolder) ; 

PrinterServicelntf printer = null; 

try{ 

printer = (PrinterServicelntf) 
^ newFolder .getService ( "myprinter" , ''PrinterServicelntf") ; 

catch (ESInvocationException esie) { 

ESXMLFile xmlQueryFile = new ESXMLFile ( "/users/ 
printerQuery.xml") ; 
ESXMLQuery printQuery - 

new ESXMLQuery (coreConnection, printQuery); 
String intfName = PrinterServicelntf .class .getName () ; 
ESServiceFinder printFinder 

new ESServiceFinder (coreConnection, intfName); 
printer = (PrinterServicelntf) printFinder . find (printQuery) ; 
newFolder . add ( "myprinter" , printer) ; 

} 

// get the contents of the folder 

String [] contents = newFolder . lis tNames () ; 

Naming Created Services 

Naming a Service which is created and adding it to a folder is 
similar to naming a found Service. The following code shows an 
example of how to name a created Seirvice. 

String propertyFileName = new String ("/users/connection. prop" ) ; 
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ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESServiceContext connectContext ^ 

coreConnection.getServiceContext 0 ; 
ESFolder current Folder = connectContext .getCurrentFolder () ; 
// The current folder is assumed to be /home/services. 
// This can be set in the properties file 
ESFolder newFolder = null; 
try { 

newFolder = currentFolder . getSubFolder { "printers " ) ; 
catch (InvalidNameException ine) { 

^newFolder = currentFolder .createSubFolder ( "printers") ; 

connectContext . setCurrentFolder (newFolder) ; 
if ( i (newFolder. containsName("f as tprinter") ) { 

ESXMLFile xmlDescriptionFile = 

new ESXMLFile ( "/users/printer. xml") ; 
ESServiceDescription printDescription = 

new ESServiceDescription (xmlDescriptionFile, 
coreConnection) ; 
ESServiceElement printElement = new ESServiceElement ( 

coreConnection, printDescription) ; 
printElement . setlmplementation (new PrinterServicelmpl ( ) ) ; 
ESServiceHandler essh = new ESServiceHandler (coreConnection) ; 
printElement .setHandler{essh) ; 

ESFolder homeFolder = coreConnection .getHomeFolder () ; 
homeFolder . add {HANDLER_NAME , essh . getAccessor ( ) ) ; 
ESAccessor printAccessor = printElement . register () ; 
printElement . start { ) ; 

newFolder. add (^f as tprinter", printAccessor) ; 

else 

{ 

ESServiceElement printElement = new 

ESServiceElement (newFolder .getAccessor fas tpr inter") ) ; 

printElement .setlmplementation (new PrinterServicelmpl () ) ; 
printElement .restart 0 ; 

} 

When the Service provider goes off-line and logs back into the e-speak Core, they 
do not have to re-create the Service. The provider looks for the name binding 
corresponding to the printer that they created and performs a restart. This allov^s 
the print Service to go online and to respond to requests. 
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An alternative way to restart services is to use the accessor of the service handler. 
A service provider can store away a binding to the service handler that was created 
to handle requests to her services in a folder. On restarting, the service handler can 
be recreated from this binding, and a service element can be recreated from the 
service handler. This allows multiple services that share a handler to be restarted 
Mdthout creating a service element for each service all over again. The following 
code snippet shows how to do this. 

ESConnection conn ^ new ESConnection ( ''propf ile" ) ; 
ESFolder home = conn . getHomeFolder ( ) ; 

ESAccessor da = home . get Accessor (HANDLER__NAME) ; 
ESServiceHandler handler = new ESServiceHandler (da) ; 
handler. setNumThreads (numThreads) ; 
ESServiceElement element = new 
ESServiceElement (handler) ; 

element . setlmplementation (new PrintServicelmpl {) ) ; 
element .restart () ; 



Creating and Finding Folders with Descriptions 

Clients can create folders and describe them in any Vocabulary just like any other 
Service. By doing this, the folders can be found by other Clients using the queries 
that are in the Vocabulary in which the folder was advertised. Creating the folders 
with descriptions allows other Clients to discover the folders and use the name 
bindings that have been created within die folders. 

For example, if Client A creates a folder with bindings for print Services that they 
want to share with Client B, Client A can create the folder with a description and 
advertise it so that Client B can discover the folder. Client B can then use the 
bindings without also having to create their own bindings. 

Some of the constructors of ESFolder, as well as some of the createSubFolder 
calls in ESFolder, take an additional ESServiceDescription that describes 
the attributes of the folder that is being created. For example: 

string propertyFileName = new String ( ^Vusers/connect ion .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
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ESXMLFile xmlDescriptionFile = new ESXMLFile ( "/users/ 
folder .xml" ) ; 

ESServiceDescription folderDescription = 

new ESServiceDescription (xmlDescriptionFile, coreConnection) ; 
ESFolder newFolder = new ESFolder { "services" , 
folderDescription) ; 

The preceding constructor of ESFolder causes the description of the folder to be 
registered in the Repository of the Core so that other Clients can discover the folder 
description. Folders are found using the ESFolderFinder class. For example: 

string propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection new 
ESConnect ion (propertyFileName) ; 

ESFolderFinder f Finder = new ESFolderFinder (coreConnection) ; 
ESXMLFile xmlQueryFile = 

new ESXMLFile ("/users/folderQuery. xml") ; 
ESXMLQuery folderQuery = 

new ESXMLQuery (coreConnection, xmlQueryFile); 
ESFolder folder = f Finder . find (folderQuery) ; 



Navigating Folders 

The ESFolder class has methods for navigating a folder hierarchy. For example, 
to get the subfolder of a given folder, there is a getSubFolder call. On the other 
hand, to get the parent of any folder, a getParent call is issued. In addition, there 
are other calls that allow the Client to list the contents of the folders. 

Scopes 

Scopes are used to mark the lifetime of transient and persistent Services. 

Before scopes can be used, boundaries need to be defined for them. The following 
method in ESServiceContext is used to signify scope boundaries: 

public void beginTransientScope ( ) ; 
public void endTransientScope ( ) ; 
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Ending a scope results in all the transient/persistent Services created in the scope 
being deleted. Furthermore, all the transient bindings for Services found by the 
Client are also deleted. For example: 

string propertyFileName = new String ( "/users/connection. prop" ) ; 
ESConnection core Connect ion = new 
ESConnection (propertyFileName) ; 
ESServiceContext connectContext = 
coreConnection.getServiceContext { ) ; 

while {notDone ( ) ) 

{ 

connectContext . beginTrans lent Scope ( ) ; 
createFindAndUseServices (core Connect ion) ; 
^ connectContext . endTransientScope ( ) ; 

In this example, the createFindAndUseServices is a method that creates and 
uses a transient Service. The end scope call following this method invocation 
automatically deletes all transient bindings and Services created in the method. 



Repository Views 

The repository view is a feature in e-speak that allows clients to restrict the scope 
of their searches to within the view. These views are collections of e-speak 
registered e-speak services. Clients can add and remove services from these views. 
These views are maintained by the e-speak core engine, therefore they are core- 
managed services. These repository views are described using ESViewDescription 
just as vocabularies are described with ESVocabularyDescription and other 
services are described with ESServiceDescription. Similarly, clients use the 
ESViewFinder to find these repository views and create ESViewElement instances 
in order to register new repository views with the core repository. 

The following code snippet shows how a client can create a repository view, find it, 
and add elements to it, etc. 
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public class testview 

{ 

public static void main (String args [] ) 

ESConnection es = null; 
try { 

String property? ileName = new String ( "/users/ 
c onnect ion. prop " ) ; 

es = new ESConnection (propertyFileName) ; 

ESViewDescription esd = new ESViewDescription ( ) / 

esd.addAttribute ("Name", "Testview") ; 

ESViewElement ese = new ESViewElement (es, esd) ; 

ESView V = ese.register 0 ; 

ESViewFinder esf = new ESViewFinder (es) ; 

ESView [] ess = esf . f indAll (new ESQuery ( "Name ^= 
'Testview' ") ) ; 

ESAccessor esa = ( (ESAccessorHandle) ess [0] ) , getAccessor ( ) ; 
{ (ESViewStub)ess[0] ) .add (esa) ; 
boolean result = false; 

result = ( (ESViewStub) ess [0] ) .contains (esa) ; 
// get all the accessors in the view 
ESAccessor [] e = ( (ESViewStub) ess [0] ). list () ; 
es .close 0 ; 
} catch (Exception e) { 

} 

} 



Restricting searches with views 

The typical use of such repository views is to restrict the search results from 
queries. This is accomplished by associating a view with a query. When an ESQuery 
with an associated view is executed by the e-speak repository, the search results 
are guaranteed to be from the elements within the repository view. 

String propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection es =^ new ESConnection (propertyFileName) ; 

System.out. print In ("Connected to core"); 
ESViewFinder esf = new ESViewFinder (es) ; 
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ESView view = esf. find (new ESQuery ( "Name == ' myPrint View ' " ) ) ; 
ESServiceFinder finder = new ESServiceFinder (es, 
"PrinterServicelntf") ; 

ESVocabulary pVocab = // . . code to find vocabulary 
ESQuery query = new ESQuery (pVocab, ^^printerSpeed == UO'"); 
query . setView (view) ; 
try { 

ESService[] list = f inder. findAll (query) ; 
for (int i = 0; i < list. length; 1++) { 

ESServiceStub printer = (ESServiceStub) list [i] ; 

ESAccessor desc f ile.getAccessor () ; 

) 

} 

catch (LookupFailedException Ife) { 

//No entries were found that matched the search criteria 

} 



Categories 

J-ESI supports the notion of categories. These categories provide a way to classify 
services so that service providers can advertise in multiple categories and clients 
can find services of interest to them in the categories of interest to diem. Each 
category is qualified by its name. Furthermore, one can create sub-categories of 
existing categories, and provide descriptions for them. When clients search for 
services, they too can set the categories that they want the search to be performed 
in. This becomes part of their query and picks out the services that are advertised 
in the categories of interest to the client. 

The category list of interest to the client/service provider is maintained in the 
ESServiceContext that is associated with the ESConnection. The following 
example shows the registration of the print service in the "high speed printer** 
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category. Essentially, the service provider sets the current category list in the 
ESServiceContext and these categories are used when registering and advertising 
the service. 

public static void main {String [] args) 
try { 

String proper tyFileName = new String ( "/users/ 
connect ion. prop") ; 

ESConnection connection = new 
ESConnection{propertyFileName) ; 

ESCategoryFinder cf = new ESCategoryFinder (connection) ; 

ESCategory root = cf . f indRootCategory { } ; 

ESCategory catl = root , createCategory ( "high speed printer", 
"high ppm" ) ; 

ESCategory [] catList = new ESCategory [2] ; 
catList [0] = root; 
catList [1] = catl; 

connect ion. get ServiceCont ext 0 . setCategory (catList) ; 
ESServiceDescription sd = new ESServiceDescription () ; 
sd . addAttribute (ESConstants . SERVICE_NAME, "printer" ) ; 
sd.addAttribute ("Description" , "my hp printer"); 
ESServiceElement se = new ESServiceElement (connection, sd) ; 
se. set Implementation (new PrinterServicelmpl ( ) ) ; 
se . register { ) ; 
se .advertise { ) ; 
se . start ( ) ; 

} catch (Exception el) { 

} ^ 

Now^, on the client side, the finder for the printers also uses the category list that is 
set in the service context. The code snippet below shows how to search for printers 
in the "high speed printer** category. Note that the client has to construct a category 
list that represents the path from the root category to the category of interest. 

public static void main (String [] args) { 
try { 

String propFileName = args[l]; 

ESConnection connection = new ESConnection ( propFileName ); 

ESCategoryFinder cf = new ESCategoryFinder (connection) ; 
ESCategory root = cf . f indRootCategory () ; 
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ESAccessorE] catlAcc = cf . find ( "high speed printer") ; 
ESCategory catl = new ESCategoryS tub {connection, catlAcc[0]); 
ESCategory[] catList = new ESCategory [2 ] ; 
catList[0] = root; 
catList [1] = catl; 

connection. getServiceContext 0 . setCategory (catList) ; 

ESQuery q = new ESQuery ( ES Const ant s . SERVICE_NAME + 
"== 'printer'") ; 

ESServiceFinder sf = new ESServiceFinder (connection, 

" Print erServicelntf " ) ; 

ESServiceE] myObjs = sf . f indAll (q) ; 

if(( myObjs == null ) || (myObj s . length ==0)) 

System. out .print In ( "ERROR IN CREATING STUB/FINDING" ); 
System.out . print In ("Foiind " + myObj s . length + " services"); 

for(int i=0; i<myObj s . length; i++) { 
PrinterServicelntf myObj = 

(PrinterServicelntf) myObjs [i] ; 
String junk = myObj .print () ; 

} 

connection. close 0 ; 
return; 
} catch {Exception el) { 
} 



Delegators 

Often, there is a need for the implementation objects associated with services to 
have access to some of the metadata of the services that the implementation object 
is associated v^ith. For example, a file implementation is to be shared amongst 
multiple files that are registered as services with e-speak. Suppose furthermore, 
that the private service specific data is used to store the actual path to the contents 
of the file on disk. In particular, suppose that the name of the service specific data 
is "RealFileName". Essentially, when the implementation object extends the 
ESDelegatorlmpl, the service specific data of the service is passed onto the 
implementation object. This allows the implementation object to determine the 
exact service for which this request is meant. 

piablic class VFSFilelmpl extends ESDelegatorlmpl { 
final static String REAL_FILE__NAME = "RealFileName" ; 
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piiblic VFSFilelmpl {ESCormection connection, ESVocabulary vocab, ESLogClient 
log, 

int numThreads) { 

/ / constructor .... 

} 

public byte[] fetchBuf f er (int offset, int size) 
throws ESInvocationException { 
try { 

String fileName = getPileName ( ) ; 
File file = new File (fileName) ; 
int count = size; 

int whatsLeft = (int) file. length () - offset; 

if (whatsLeft < count) { 
count - whatsLeft; 

byte [] fileBuffer = new byte[coxint] ; 

Filelnput Stream in = new FilelnputStream (f ile) ; 

in. skip ( (long)of f set) ; 

in.read{f ileBuf f er) ; 

in. close { ) ; 

return fileBuffer; 
} catch (Exception ioe) { 
} finally { 
} 



private String getFileName ( ) { 
try { 

byte[] entry = getPrivateData (REAL_FILE_NAME) ; 
String fileName = new String (entry) ; 
return fileName; 
} finally { 
} 

} 
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So far, the discussion has focused on how e-speak Clients can register and discover 
new Services while using folders to manage Service bindings. No mention has been 
made yet of multiple connected Cores, the distributed nature of deployments, or the 
impact of distribution on failure semantics, latency, and concurrency. 

J-ESI makes it easy for programmers to write distributed Services, Although all 
Services are registered in the local Core by default, these can be made more widely 
visible by advertising this Service across multiple Cores. In J-ESI, the possible 
domains in which a Service is visible are as follows: 

• Only the e-speak Core— In this deployment scenario, all Clients that want to 
use this Service are also connected to the same Core, loosely representative of 
a classic Client-server deployment of Services. 

• , In an e-speak group — An e-speak group is a collection of e-speak Cores that are 
closely connected to each other, such as in an administrative domain. These 
Cores typically can find all Services registered in any of the other Cores, and 
they may all share the same back-end server (possibly an LDAP server) for 
storing all Services registered in the group. E-services Village, a HP hosted 
service directory is an example of such a service directory. Such deployments 
are analogous to lookup or naming servers used in other solutions. Note: The 
advertising services vrtthout LDAP should use the same group name in the 
command line -group <groupname> option if they want to be part of the same 
group. 

• In an e-speak community— An e-speak community is a Client-defined named 
set of e-speak groups that is created by Clients to enable them to search through 
different related sets of Services easily. The default community in J-ESI includes 
www.eservicesvillage.com. Therefore, every query that any client executes 
returns results that are not only in the local core, but also in eservices village. 

In Figure 13, the top left comer shows a single Core case where all Clients and 
Service providers are connected to the same Core. The top right comer shows an e- 
speak group in which a closely connected group of Cores share an LDAP server or 
use other mechanisms to advertise all their Services to each other. The bottom 
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figure shows an e-speak community that can be formed between groups A and B. A 
Client in group A can select to find Services in group B, by setting the community 
list to include group B. 




Figure 1 3 E-speak Core groups 



A Service provider can advertise the Service in the local advertising service or can 
advertise it to different groups. The Service provider can do so by using either the 
advertise call or advertiselnOtherGroups method in 
ESServiceElement . 

Consider an example where there are a number of printers organized according to 
administrative groups. Additionally, assume that each administrative group is 
associated with a different e-speak group. A user wanting to find printers across all 
administrative groups but still located closest to the user performs the following 
steps: 

1 Create their own community that lists the groups of all the relevant 

administrative domains. Each group is identified by a string with the following 
format: 



106 



Developer Release X.03.03.0Q, September 2000 



Extended Services 



Communities 



<host_name> : <port_num>/<group_name> 

The host name and port number identify the host machine in which an advertis- 
ing Service for the group of interest can be found. In addition, the name of the 
group of interest is specified as well. Note: The port is that of the connection 
factory and not of the Core. The advertising service should have been started 
with the same group name, with the command line option -group < group - 
naTne>. 

ESCommunity newCommunity = new ESCommunity (coreConnection) ; 
newCommunity . add ( "host 1 : 22 02 0/auction_sitel" ) ; 
newCommunity. add (''host2 :22021/auction_site2" ) ; 

Another way to create a community is to specify it in the properties file used on 
start-up. The properties file takes in a community property that is a comma- 
delimited list of groups such as: 

printcommunity.prop file: 
community = hostl : 22020/auction_sitel, host2 :22021/auction_site2 

2 Set the current community to this community name using the 
ESServiceContext class: 

ESServiceContext connect Context = 

coreConnection. getServiceContext 0 ; 
connect Context . set Community {newCommunity) ; 

3 Perform a search as follows: 

ESServiceFinder anyPinder = 

new ESServiceFinder (coreConnection) ; 
anyFinder . find ( "'Name == ' AnyService "' ) ; 

A mobile user can simply switch the connmumty profile to find the appropriate 
Services in the currently relevant community. 

In fact, because e-speak is geared toward Service deployment, it is natural to 
simplify the process of advertising a Service across a wide geographical area, 
simplify searching, and provide distributed access control. 
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To simplify the programming of distributed Services, the following support is built 
intoJ-ESI: 

• Advertising a Service automatically makes the Service visible to the group in 
which it has been advertised. 

• Because each Core has a registry, an e-speak deployment does not require a 
centralized naming or lookup Service to obtain information about all Services 
registered. A centralized scheme can be implemented as a special case within a 
more general scheme enabled by e-speak finder Services. The search for a 
Service is automatically performed in parallel across multiple registries. 

Advertising across internet and locally 

Advertising service across the Internet using HP hosted global service 
directory 

Service providers can advertise the services throughout the world using HP hosted 
global service directory by selecting default values when starting the advertising 
service. In this case, when user invokes the advertise 0 call, the service gets 
advertised in the global service directory. This allows a service provider located in 
Los Angles to advertise a service to the global directory, accessible by any clients in 
New York. Clients and service providers can use the hosted gateway/connector 
service at eservicesvillagexom to access and provide services from behind a 
firewall. 

For services hosted behind a firewall to advertise themselves at 
eservicesvillage.com (or any other service directory on the internet), the service 
provider has to set up the configuration files appropriately. The sections of the e- 
speak configuration file that pertain to web-proxy configuration and advertising 
service configuration may have to be modified in order for this to work correctly. 
The following is a sample section from an e-speak configuration file with the rules 
for web-proxy and advertising service configuration. 



Web proxy configuration 

webproxyname is a single value being the fully qualified hostname 
of the http -proxy used to traverse a firewall 
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net . espeak . infra . core . connector . webproxyname^web -proxy. ef gi jk . com 

1 webproxyport is the port on which the proxy listens 
net . espeak . infra . core . connector . webproxyport =8 088 

i domain for which direct connection should be done. 
1 only one entry is supported currently 
i Syntax is the end of the domain that should be match 
! the wildcard is not supported. 

net . espeak . infra . core . connector . noproxydomain^ef gi j k . com 



1 Advertising Proxy configuration 

J host at which the core for advertising proxy is running 
net . espeak . services . advertise . esv_proxy_host=XXXXXXXX 
{needs to be fixed*****************************************) 

iport at which the core for advertising proxy is running 
net . espeak . services . advertise . esv_j)roxy_j)ort=2 3456 

idefault username and password to be used at the e-services village 
net . espeak . services . advertise . esv_user__name=%esv_username% 
net . espeak . services .advertise . esv_password=%esv_j)assword% 

If service providers who advertise their service have created an account at 
eservicesvillage.com, they can edit the esv_user_name and esv_password fields in 
the configuration file above to the appropriate values. This allows them to login to 
eservicesvillage and manage/edit their services. 

Advertising a service within an enterprise 

Service providers can advertise the services within an enterprise in two ways, 

• Using a service directory (say LDAP) 

• Using only the e-speak core repository 

The first scenario is similar to using HP hosted global service directory except that 
the advertising service connects to the service directory specified by the service 
provider. This service directory can be located within the enterprise spread in 
different locations. Specifically, the advertising service is started by specifying (- 



Developer Release X.03.03.00, September 2000 



109 



Communities 



Extended Services 



beproto <protocol>), (-behost <hostname>) and (-beport 
<portnumber>) command line options. If (-beproto) command line option is 
not specified, then global service directory hosted by HP is selected. 

In the second scenario, service providers who do not want to use service directory 
like LDAP can still achieve the same results by starting the advertising service in 
'With repository mode'. When the user invokes the advertise 0 call, the service is 
placed in the local advertising service. 

In this case, clients doing a search in a community, can specify fully qualified group 
names (group name+host name+port number). The infrastructure automatically 
connects and makes all the services available in the advertising service identified by 
host name and port number visible to the client, even when not using any service 
directory. 

Advertising a service in local domain 

Service providers advertising service in the local domain can do so in the following 
two ways. 

• Using a service directory (say LDAP) 

• Using only the e-speak core repository 
The first scenario is same as described above. 

In the second scenario, the users can use the spontaneous discovery mechanism in 
die e-speak system. Service provider's advertisements are automatically 
transferred to all the advertising services belonging to the same group. 

Clients doing a search in a community, need to specify only the group names. The 
hostname and portnumber are no longer necessary in the local domain, as the 
advertising services spontaneously talk with each other in the local domain and 
exchange information. 

Multiple groups in a single service directory 

Multiple groups can be in a single service directory (say LDAP). In this case, 
different advertising services belonging to different groups can connect to the same 
service directory and advertise services. 
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Selecting a group name 

Two different service providers can advertise services with exactly the same 
descriptions (attribute values). If the service provider wants to prevent collisions 
across the advertised services or wants to protect the access to the services 
advertised, the service provider can specify sufficiently unique group name for the 
advertising service. Specifically the service provider uses (-group 
<groupname >) command line option of advertising service to achieve this. It is the 
service provider's and cUent's responsibility to select a sufficiently unique name for 
the groups to prevent collisions. 

A client doing a search can specify a community which is a collection of group 
names. In this case, only services registered in the those groups are returned to the 
client. Services in other groups, even if matching client's query are not returned. 

A service provider wishing to advertise the service to the whole world can do so by 
starting the advertising service witfi group name ' speaktome ' and using the HP 
hosted global service directory. Specifically, the service provider starts the 
advertising service with command line option (-group " speaktome ") 

Setting Current Community 

The following two Application Programming Interfaces (APIs) in the 
ESServiceContext class are used to create the community in which a search or 
a registration of a Service is to be performed. 

The getCurrentCoramunity and setCommunity methods are as follows: 

public ESCommunity getCurrentCommunity ( ) ; 
public void setCommunity (ESCommunity community); 

ESCommunity 

To add an entry to the list of groups, use the follovdng code: 

public void add (String groupName) ; 
The default community is defined by the start-up file. 
To remove a group from the community, use the following code: 



Developer Release X.03.03.00, September 2000 



111 



Communities 



Extended Services 



public void remove (String groupName) ; 
NOTE: Note: This is included in future releases. 
To return the enumeration of group servers, use the following method: 

public Enumeration listGroupServers { ) ; 
Example: csldemoB , rgv.hp.com: 22 022 /group. 

Advertising to Groups 

As mentioned earlier, advertisement of Services is managed by 
ESServiceElement. An advertise call makes the Service visible to the entire 
group. To advertise a Service, use the following method: 

public void advertise () ; 

If a Service needs to be advertised to a different set of groups, use the following 
method: 

public void advert iseToOtherGroups {String [] groupNames) 

where each element in groupNames is in the form 
<hostname> :portnumber/name. 

Finding in Communities 

All the user needs to do to find a Service in a community is to set the current 
community to the one of interest and invoke the finder method to find the Service. 

ESServiceContext connectContext = 

coreCormection . getServiceContext ( ) ; 
connectContext . setCommunity (owncommunity) ; 

finder. find (query) ; 
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Security 

The most basic notion in security is the notion of identity that is determined by its 
key-pair. In order to invoke operations on a security-enabled service, a client 
requires an appropriate certificate. This certificate must be signed either by the 
service provider's principal himself or by another principal who is linked by a chain 
of delegation to a principal listed in the trust assumptions of the service provider. 
With security enabled in the core, service providers and service client require 
certificates to enable them access to core apis. For instance, to register a service 
and to perform find operations. The principal representing the core issues 
certificates to both chent and provider enabling such access. 

When security is enabled, start up of any e-speak client (service client or service 
provider) reads two files: the trust assumptions and the certificates. Both these are 
actually just lists of certificates: the former being used by a service provider and the 
latter being used by a service client. In the base case, the service provider requires 
only one certificate: that for accessing the core. The service client, on the other 
hand, requires one for accessing the core and one or more for accessing the service 
itself The client certificate list is merely a concatenation of these. An example of a 
certificate that the core can provide a service provider looks as follows, the binary 
data has been truncated for brevity. 

(signed (cert 

(issuer (public-key elgamal -pkcsl 
"\003\017v\245\235b\004\345\211\225\021 [\203=\256/ 

K\256\375\032\217:\351\024\327\304\342\312B\'\311\016\007\3 04^\2 052\322\27 
l@\304^<\370\204\036j\220\030\2217aD*\242\335|\233H\334N\201?.Uq\236) ") ) 

(subject (public-key "elgamal -pkcsl" 
"\003\017v\245\235b\004\345\211\225\021 [\203=\256/ 

K\256\375\032\217: \351\024\327\3 04\342\312B\ '\311\016\007\304^\2 052\322\31 
6r+") ) 

(propagate) 

(tag (net .espeak. method (*) {*) (*))) 

(net-before 2000-05-25_10 : 15 :28) 

(not-after 3000-05-25_10 : 15 :28) 

) (signature (hash SHA-1 
"\032\356V\317\260\t\347\331\277] \'\0278\237\0301t\212#\210") (public-key 
elgamal -pkcsl "\003\017v\245\235b\004\345\211\225\021 [\203=\256/ 
K\256\375\032\217:\351\024\327\304\342\312B\'\311\016\007\304"\2052\201?.U 
q\236) ") 

"\0 03\017"97\317"\377\ '\303\347yC\337+\221$Sm\202\242\201\214w\0 04\352&\31 
0]U-/\272\\342\301\330\034«) ) 
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A certificate that a service provider, a print service in this example, provides to a 
client that allows the client to invoke an operation, such as print, on it looks as 
foUov^s (the binary data has been chopped): 

(signed {cert 

(issuer (public-key elgamal-pkcsl 

"\003\017v\245\235b\004\345\211\225\021[\203=\256/K\256\364p\255|\335") ) 

(subject (public-key "elgamal-pkcsl" 
"\003\017v\245\235b\004\345\211\225\021 [\203=\256/ 
K\256\311\301\273\3071\323\316r+") ) 

(propagate) 

(tag (net .espeak. method PrinterServicelntf {* set print) (*))) 

(not-before 2000-05-25_10 : 15 : 28) 

(not-after 3000-05-25_10 : 15 :28) 

) (signature (hash SHA-1 
"\0237\340}\' \310I\2638mq\207V\265\357\342\201\2702\274") 
(public-key elgamal-pkcsl 

"\003\017v\24 5\235b\004\345\211\225\021 [\203=\256/ 

K\246\374\032\020\244\004\004T\3 07\221\037\247\034\332\365\3648-\300\274\3 
62") ) 

When a message invoking an operation is received, J-ESI extracts the interface and 
method from it, and gets the service identifier from the information passed to the 
service handler by the core. From this it constructs the tag required to authorize the 
operation. The authorizer first checks to see if the tag is contained in the resource 
mask, and if it does, the operation is permitted. If the operation is not in the mask, 
J-ESI looks for a valid certificate (or certificates) that contain the tag needed to 
invoke the operation. The tag matching rules used for authorization are explained 
in the E-speak Architecture Specification chapter on "Access Control". The 
certificates checked by J-ESI are those presented by the client to establish the 
session 

J-ESI provides service providers with means to set metadata and resource masks 
that can mask access control to their services. See Appendix H for details on how 
to set up your security environments in e-speak. 

The default behavior when security is enabled is to require authorization for all 
operations. Service providers can create masks and associate them with service 
elements that they create. Masks enable Service providers to allow operations 
without any authorization. Any client is allowed to perform any operation that is 
specified in the mask for the service. If an operation is not included in a mask, only 
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clients that have been given certificates authorizing access are allowed to invoke 
the operation. The security infrastructure examines the certificates that have been 
presented by the client to see if they contain a tag authorizing the operation. The 
rules for how tags authorize operations are explained in the E-speak Architecture 
Specification "Access ControF chapter. 

Masks 

There are two types of masks: the metadata mask for metadata operations and the 
resource mask for resource specific operations. For example, service providers can 
control who can mutate the metadata of the service that they have created using the 
metadata masks, and they control who can invoke operations on services provided 
by them using the resource specific masks. 

Masks are specified as tags. The basic method tag format is 

(net . espeak .method <interface name> <method name>) 

The tag format is explained in detail in the E-speak Architecture Specification 
"Access Contror chapter. In the metadata mask, the interface name is the core 
interface being specified, and the method name is the operation in that interface. 
For metadata, the interface is likely to be ResourceManipulationlnterface, and the 
method name one of its methods. 

In the resource mask for a J-ESI service the interface name is the fully-qualified 
name of the interface class. The method name is the name of the method in the 
interface, plus the concatenated argument types. This allows overloaded methods 
to be distinguished. 

The metadata mask is used by the in-core metaresource when performing metadata 
operations. The resource mask is passed to the service handler by the core for the 
service handler to use when performing operations on the service itself. 

The masks are completely general tags, so the mask tag itself, or any of its fields, 
may use the tag matching features such as sets, prefixes and ranges. The interface 
and method names, for example, do not have to be string literals, they can be sets 
or prefixes. 

This tag masks method foo in interface net.espeak.examples.ExampleIntf: 
(net . espeak. method net .espeak. examples .Examplelntf foo) 
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This tag masks all methods beginning with foo: 

(net .e speak. method net , e speak, exanples . Example Intf 
(* prefix foo) ) 

This tag masks methods foo and bar: 

(net . espeak . method net . espeak , examples . Exampleint f 
(* set foo bar) ) 

Methods with prefix foo or bar: 

(net . espeak . method net . espeak . examples . Exampleint f 
(* set (* prefix foo) (* prefix bar))) 

All methods in the interface: 

(net .espeak. method net .espeak. examples .Example In tf ) 

This is equivalent to 

(net . espeak. method net .espeak. example s . Example Intf (*) ) 

since missing trailing elements match anything. 

Methods foo in InterfaceA and bar in InterfaceB: 

(* set (net . espeak. method InterfaceA foo) 
(net .espeak. method InterfaceB bar)) 

All methods: 

(net . espeak . method) 
or simply 
(*) 

The full form of the method tag is actually: 

(net . espeak .method <interface name> <method name> <service>) 

In the normal case, the service handler is only interested in its own operations, so 
it does not care what the service field is. Since omitting a trailing field is equivalent 
to giving it the value (*), we omitted this detail above. 
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Authorizing Access 

General tags can be constructed using the following method in ESSecurityEnv: 

ADR createTag (String s) throws lOException 

The lOException subclass net.espeak.security.adr.ADRParseException is thrown 
on a parse error. The parameter s is a string containing the input syntax for the tag. 

Method tags can be created using 

ADR createMethodTag (String interf aceName, 
String methodName , 
ADR service) 

Clients can retrieve their current security environment from the connection. For 
example: 

ESConnection conn= new ESConnect ion ( ''config . file" ) ; 
ESSecurityEnv secEnv = conn.getSecurityEnv () ; 

For the purposes of resource masks, it is usual to use a tag containing simply (*) as 
the service parameter. In advanced applications, the service may want to set the 
service parameter to its service id, but this is not necessary. 

After a mask tag has been constructed, it is used in ESServiceElement methods: 

void setResourceMask (ADR tag) throws ESException 
void setMetadataMask (ADR tag) throws ESException 

Before a service is registered, these simply affect the local state. After registration, 
these set the local state and update the service metadata. 

Masking can be turned on or off using ESAuthorizer: 

void setMasking (Boolean x) 

When masking is off, the resource mask is ignored by the service authorizer even if 
set. Setting masking off in the authorizer has no effect on the resource metadata, or 
the in-core metaresource handling metadata operations. Masking can be turned off 
completely, in the core and handler, by setting a mask to null. 
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An ESAuthorizer is associated witii each ESServiceElement, and one can obtain the 
authorizer associated with an ESServiceElement using the getAuthorizerQ call in 
ESServiceElement. 

ESConnection has methods for controlling the default resource and metadata 
masks used when services are registered: 

void setDef aultResourceMask {ADR mask) 
ADR getDef aultResourceMask 0 
void setDef aultMetadataMask (ADR mask) 
ADR getDef aultMetadataMask 0 

void setMasks(ADR metadataMask, ADR resourceMask) 

After a default mask is set, all resources registered use it until it is changed. Unless 
the default masks are set explicitly, ESConnection uses null for them, causing 
authorization to be checked for all operations. 

Example 

In the example below, the service provider sets up a mask for the print method and 
a mask for the checkStatus method. Clients who present tags that match the print 
method are allowed to print and all clients are allowed to invoke the checkStatus 
method. The access control for the checkStatus method is disabled because of the 
setResourceMask mediod invocation in ESServiceElement, 

public static void main (String [] args) 
{ 

try { 

ESConnection conn = new ESConnection { ''espeak.cfg" ) ; 
ESSecurityEnv sEnv - conn.getSecurityEnvO ; 

String m2 = 'Mnet . espeak. method PrinterServicelntf checkStatus)"; 
ADR adr2 - sEnv.createTag{m2) ; 

ESServiceDescription sd ~ new ESServiceDescription {) ; 
sd.addAttribute (ESConstants .SERVICE_NAME, "printer") ; 
sd.addAttribute { "Description" , "my hp printer"); 
ESServiceElement se = new ESServiceElement (conn, sd) ; 
se. setResourceMask (adr2) ; 

ESAuthorizer esa = (ESAuthorizer) se .getAuthorizer ( ) ; 
esa. setMasking (true) ; 

se . setlmplementation (new PrinterServicelmpl ( ) ) ; 
se. register 0 ; 
se. advertise ( ) ; 
se. start ( ) ; 
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} catch (Exception e) { 
e .printStackTrace ( ) ; 

} 

} 

Clients who want to invoke this print service must obtain the tags to invoke this 
service and install them in their security environment. 

Remote Connection Manager 

Using advertising service, groups and communities is the preferred way of 
exchanging service metadata between various cores. However, sometimes more 
fine grained control is required where you want to make the service available to a 
specific core or engine. This can be done with the aid of remote connection 
manager and remote service manager. 

Remote connection manager has set of simple methods that allows the application 
programmer to connect to the specified core, to disconnect from a core and to get 
a list of all connections that the local core maintains with o±er cores. To do this, 
first obtain the remote connection manager object from ESConnection. 

ESConnection conn = new ESConnect ion ( ''file .prop" ) ; 
ESRemoteConnectionManager connMgr - 
conn . getConnectionManager ( ) ; 

To open a connection to a remote core, the client can invoke the openConnectionQ 
method on the connection manager. Typically, the client specifies the address and 
port number on the remote machine on which the remote core is running. 

string url = "tcp :abc . foo. com: 12345" ; 
String id = connMgr . openConnect ion (url) ; 

Clients can close existing connections with remote cores by invoking the 
closeConnection method in the connection manager. For example: 

connMgr .closeConnect ion (id) ; 

where id is the string that represents the id of the connection that is returned by the 
openConnectionQ call. To get a list of connections that are currently open with the 
connection manager, use the following call. 

String[] ids = connMgr .get Connect ions {) ; 



Developer Release X.03.03.00, September 2000 



119 



Security 



Extended Services 



Exporting Vocabularies 

Before a Service can be exported, the Vocabulary it will use must be exported. An 
example of this follows: 

package tests . j ava . net . espeak . j as i . remote ; 
import net .espeak. jesi.*; 
import net . espeak . infra . cci . exception . * ; 
ptablic class Export 

{ 

public static void main (String args [] ) throws Exception 
{ 

ESConnection es = new ESConnection("localhost",12345, "TCP") ; 
System, out . pr int In ("Connected to the first core\n"); 
ESRemoteServiceManager servMgr = es .getRemoteServiceManager { ) ; 
ESRemoteConnectionManager connMgr - es .getConnectionManager ( ) ; 

//Creating the vocabulary 

ESVocabularyDescription vocabDesc = new 
ESVocabularyDe script ion ( ) ; 

//Setting the vocabulary name 

vocabDesc.addAttributeC'Name", "ESR_002Vocab" ) ; 

//Adding vocabulary properties 

vocabDesc . addStr ingProperty ( " testCaselD " ) ; 

//Registering the vocabulary 

ESVocabularyElement vocabElem = new 
ESVocabularyElement (es, vocabDesc) ; 

ESVocabulary vocabRegister = vocabElem. register () ; 
System. out .println ("Vocab registered") ; 

ESAccessor [] accList - new ESAccessor [1] ; 
accList[0] = ( (ESAccessorHandle) vocabRegister) .getAccessorO ; 
System. out .print In ("Exporting resources : " + accList[0]); 

// Connection to second core 

ESConnection connection = new 
ESConnect ion ( "localhost", 12346, "TCP") ; 

System. out . pr int In ("Connected to the second core"); 

ESVocabularyFinder vocabFind = new 
ESVocabularyFinder (connection) ; 

try 

{ 

ESVocabulary vocabTemp = vocabFind. find ( new ESQuery( 

"Name == • ESR_002Vocab ' " )); 
} catch (LookupFailedExcept ion look) { 

System. out . print In ("Lookup before Export Failed");} 
/ /Export 

servMgr . exportService ( accList , 

connMgr.openConnection("tcp:localhost: 12346" ) , 
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ESConstants . EXPORT_BY_VALUE , 
true) ; 

//find vocab after Export 

ESVocabulary vocabl - vocabFind. f ind ( new ESQuery( 

"Name == ' ESR_0 02 Vocab ' " )); 
ESAccessor accessl - ( (ESAccessorHandle) vocabl) .getAccessor {) ; 
if (accessl-=:null} 

System. out .print In ( "Error" ) ; 

else 

System. out. print In ("Lookup after Export Success"); 
System.out . print In (" *********** SUCCESS DONE 

} 

} 

Exporting Services 

Remote service manager is used to control transfer of service metadata from one 
core to another. This allows clients of one core to export their service descriptions 
to other cores on a selective basis. The remote service manager is obtained from the 
ESConnection by 

ESConnection conn = new ESConnection ("file. prop" ) ; 
ESRemoteServiceManager servMgr = 
conn . getRemoteServiceManager { ) ; 

Nov^, suppose the service provider has registered a series of services with the e- 
speak core and has the accessors for the service in an array of ESAccessors called 
accessors. Furthermore, suppose that the id of the core to which the service 
provider has opened a connection is id. Additionally, the exporter has to specify 
whether the export should occur by value or by reference, and in the case of 
accessors corresponding to folders, the exporter has to determine whether the 
export should recursively export sub folders of the current folder, or should it 
export only the current folder. The invocation of the exportResource method looks 
as follows: 

servMgr.exportService (accessors, id, exportType, level) ; 
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The exportType is an integer that is 1 if the services are to be exported by value and 
2 if the services are to be exported by reference. In addition, set the boolean flag, 
level to false if the contents of a folder are to be recursively exported, and to true if 
only the top level of the folder is to be exported. A similar interface can be used to 
import resources. 

servMgr.importService (accessor, id, importType, level) ; 
To unexport an exported resource from a remote core, the service can invoke: 

servMgr .unexportService (accessor, id) ; 
To unimport an imported resource, the service provider can invoke: 

servMgr .iinimportService (accessor, id) ; 



Events 

This section describes the design details of the Event Service, a lightweight, 
extensible Service targeted at loosely coupled, distributed applications. Events 
provide a publish-subscribe mechanism for communication built on top of e-speak 
messaging. 
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E-speak supports an extended form of the familiar publish-subscribe Event Model 
There are four logical entities in the e-speak Event Model whose interactions are 
shown in Figure 14. These entities are the Publisher, Listener, Distributor, and 
Subscriber 



Figure 14 Interactions in the Event Model 

A Publisher (marked P in the figure) is an entity that generates an Event notification 
message. The recipient of an Event notification is called a Listener (L) . A Distributor 
(D) is an extension of a Listener. It receives Events and forwards them to other 
Listeners. A Subscriber (S) is an entity that registers interest in a particular Event 
with a Distributor and designates the Listener to whom Events are sent. The 
Subscriber and the Listener are typically the same physical entity. Similarly, it is 
fairly typical for a Publisher to act as a Distributor of its own Events. 

The Core itself is an example of an Event Publisher. It sends Events to a trusted 
Client called the Core Distributor to signal state changes such as a change in a 
Service's attributes. The Core Distributor can then distribute these Events to 
interested Clients that have appropriate authority. 





notiiy(event) 



Listener 
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Interaction Sequence 

Figure 15 shows a typical Event notification process where the Subscriber and 
Listener are folded into a single Client. 




L » Core 

Figure 15 Typical Event notification process 

The following numbers in the figure represent these steps in the process: 

1 Distributor registers with the Core. 

2 Publisher discovers the Distributor. 

3 Publisher sends publ i sh request to the Distributor describing the Events it will 
be generating. 

4 Subscriber discovers the Distributor. 

5 Subscriber sends subscribe request to a Distributor describing the Events in 
which it is interested. 

6 Publisher sends the Event to the Distributor using a notify message. 

7 Distributor forwards the Event to the Subscriber (also using a notify request). 
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Subscribing to Events 

The Event APIs provide simple mechanism by which Clients can express interest in 
various Events and handle them. The following code shows how a printer Client 
subscribes to outofpaper and paperjam Events and handle them subsequently. 

string propertyFileName = new String ("/users/connection. prop" ) ; 
ESConnection coreConnection = new ESConnect ion (propertyFileName) ; 



ESSubscriber printerEventSubscriber = 

new ESSubscriber (coreConnection) ; 
printerEventSubscriber . addEvent 

{ "hp . headof f ice . first floor .printer . outofpaper" ) ; 
printerEventSubscriber .addEvent { 

{ "hp . headof f ice . f irst floor .printer .paper j am" ) ; 
printerEventSubscriber . setlmplementation 

(new PrinterEventHandler 0 ) ; 
ResultSet rs = printerEventS\ibscriber. subscribe {) ; 

public class Print EventHandler implements ESListnerlntf 

( 



public string not if ySync (Event evt) 

{ 

System.out .print In (evt .get Pay load 0 } ; 
return "Notified" ; 

} 

public void notify (Event evt) 

{ 

System . out , print In ( evt . get Pay load () ) ; 

} 



The event subscriber, after connecting to the e-speak core, creates an instance of 
ESSubscriber and expresses interest in certain event using addEvent call. 
Furthermore, the subscriber sets the handler for the Events in which it is interested 
using setlmplementation ( ) . The handler should implement the 
ESListenerlntf . Then the subscriber invokes subscribe ( ) to register with 
the existing distributors in the community. The community is set using 
setCommunityO call in ESServiceContext. The ResultSet obtained as a 
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result of subscribe 0 call contains success or failure of subscription with 
different distributors. The subscriber can subscribe to e-speak service events in a 
similar manner. The subscriber can also subscribe to e-speak core events using 
ESCoreSubscriber class. The list of e-speak service and core events are 
mentioned towards the end of this section. 

The following code gives a simple example of how to subscribe to service events, 
for e.g., service.create. This subscribes the user to any service creation events in the 
community. 

string propertyFileName = new String ("/users/connection. prop" ) ; 
ESConnection coreConnection = new ES Connect ion (propertyFileName) ; 



ESSubscriber serviceCreateSiibscriber = 

new ESSubscriber (coreConnection) ; 
serviceCreateSiibscriber . addEvent 

("service.create") ; 
serviceCreateSubscriber . set Implement at ion 

(new Print erEventHandl er ( ) ) ; 
ResultSet rs = serviceCreateSubscriber . subscribe () ; 

Publishing Events 

Publishing events is done using the ESPublisher class. The usage is similar to that 
of subscribing to events. 

string propertyFileName = new String ('Vusers/ connect ion. prop" ) ; 
ESConnection coreConnection = new ESConnection (propertyFileName) ; 



ESPublisher printerEventPublisher = new 

ESPublisher (coreConnection) ; 
printerEventPublisher . addEvent 

( ^*hp . headof f ice . first floor .printer . out of paper" ) ; 
printerEventPublisher . addEvent ( 

( ''hp . headof f ice . firstfloor .printer .paper j am" ) ; 
printerEventPublisher .piiblishO ; 



Event out of paper Event = 

new Event ( ''hp .headof f ice. firstfloor .printer .outof paper" ) ; 
outofpaperEvent.setPayload( "printer foo out of A4 paper"); 
printerEventP\iblisher . sendNotify (outofpaperEvent ) ; 
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Just as the subscriber expresses interest in receiving events, the publisher 
expresses interest in sending events. The publisher does this by instantiating the 
ESPublisher class, adding events of interest using addEvent and then calling 
publish ( ) . publishO does not send an event to the consumer, rather it just 
expresses intent to publish those events at a later point of time. Actual publishing 
of events takes place when the publisher calls sendNot i f y ( ) after constructing 
an Event object. There is a default publisher available with the ESConnection 
that can be obtained using the getDef aultPublisherO call. This is used for 
publishing only the e-speak service events. The list of service events is given at the 
end of this section. 

Distributing Events 

So far we have talked about a simple subscriber and publisher assuming that there 
is already a distributor is available for the outofpaper and paperjam events. In case 
no such distributor is available, the publisher of the events can write a simple Event 
distributor as follows. 

string propertyFileName = new String ('Vusers/connection. prop" ) ; 
ESConnection coreConnection = new ESConnection (propertyFileName) ; 

ESDistributor printerEventDistributor = new 

ESDistributor (coreConnection) ; 
printerEventDistributor .addEvent 

( "hp . headof f ice . first floor . printer . outofpaper" ) ; 
printerEventDistributor . addEvent ( 

( "hp . headof f i ce . f i r st f loor . printer . paper j am" ) ; 
printerEventDistributor .start () ; 

printerEventDistributor . shutdown ( ) ; 

The distributor creates an instance of ESDistributor and adds events which the 
distributor intends to distribute using the addEvent ( ) call. The distributor then 
starts using the start ( ) call. The distributor can be stopped using shutdown 0 
call There are some pre-existing Event distributors bundled with the e-speak core. 
These are started along with the e-speak core. They are the service distributor and 
the core distributor. These distribute the service and core events listed at the end of 
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this section. It is possible to subscribe to core events distributed by the 
ESCoreDistributor. It is possible also to subscribe and to publish service 
events that are distributed by the ESServiceDistributor, 

List of Service Events 

This section lists the Service Events generated by e-speak. 

service • create This Event is generated by e-speak Service interface 

when a Service is created. 

service. mutate This Event is generated when a Service s attributes 

are mutated. 

service . delete This Event is generated on deletion of a Service in 

the e-speak Service interface. 

service . access This Event is generated whenever the ESAccessor 

of a Service is used. 

service . pause A Service can voluntarily generate this Event for 

temporary pause of its Services, 

service . resume A Service can voluntarily generate this Event on 

resumption of its Services. 

service . genericinf A Service sends out generic information about itself 
° through this Event type. 



List of Core-Generated Events 

This section lists the Events 

core .mutate .NameFramelnter face . 3 
core .mutate .NameFramelnter face . 4 
core .mutate . NameFramelnter face . 5 



generated by the e-speak Core. 

Bind a Resource to a new name in an 
existing Name Frame. 

Rebind an existing name in a Name 
Frame to a new Resource. 

Unbind a name from a Resource. 
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core .mutate .NameFraiae Inter face . 6 

core .mutate .NameFramelnter face . 7 

core .mutate .NameFramelnter face * 8 

core .mutate .Vocabularylnter face . 3 

core . mutate . ResourceFac torylnter f ace . 1 

core , mutate . ImporterExporterlnterf ace , 1 

core .mutate . ImporterExporterlnterf ace . 5 

core . mutate . ResourceManipula tionlnter f ace . 
1 

core .mutate . ResourceManipulationlnterf ace . 
3 

core .mutate .ResourceManipulationlnterf ace • 
5 

core . mutate . ResourceManipulationlnterf ace . 
9 

core .mutate . ResourceManipulationlnterf ace • 
11 

core . mutate . ResourceManipulationlnterf ace . 
13 

core .mutate . ResourceMcinipulationlnterf ace . 
23 

core . failure . invalid_jparameter 
core . failure .null jparameter 
core . failure . invalid_value 
core . failure . invalid_type 
core . failure . out_of _order 
core . failure . Core_panic 



Copy a binding from one Name Frame 
to another. 

Add a binding to a Resource to an 
existing name. 

Remove a binding to a Resource from 
an existing name. 

Modify the attribute set of a 
Vocabulary. 

Register a new Resource. 
Import a new Resource. 
Update an imported Resource. 
Unregister a Resource. 

Modify the owner of a Resource, 

Modify the handler of a Resource. 

Modify a public RSD of the Resource. 

Modify a private RSD of the Resource. 

Modify the attributes of the Resource. 

Modify the export-type of the 
Resource. 

Pass an invalid parameter. 
Pass a null parameter. 
Receive an invalid value. 
Receive an invalid type. 
Out of order. 

Core has an irretrievable exception. 
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core . failure . service_panic 
core . failure . recover able_Core 
core . failure . repository_f ull 
core . failure .partial_status__update 
core . failure . request_not_delivered 
core - failure .pennission_denied 
core. failure .\mdeliverable_request 
core . f ai lure .unre cover able_de livery 
core . failure . recoverable_delivery 
core . failure . quota__exhaus ted 
core . f ai lure . naming 
core . failure , eiapty_inapping 
core . failure .unre sol ved__binding 

core . failure .multiple__resolved_binding 

core . f ailure .naine__not_f ound 
core . failure . stale_entry_access 
core * failure . naiae_collision 
core . failure . lookup_f ailed 
core • failure • service__f ailed 
core . f ai lure . name f r ame_f ai 1 ed 
core . failure . invocation_f ailed 
core . failure . invalid_name 
core . failure . remote 
core • failure . exporter 
core . failure . exception 



Service has a critical exception. 

Received exception recoverable. 

Repository is overflowing. 

Status update is partial. 

Request not delivered. 

Permission denied for this operation. 

Request is not deliverable. 

Unrecoverable delivery exception. 

Recoverable delivery exception. 

Resource quota exhausted. 

Naming exception received. 

Mapping empty exception. 

Exception in binding resolution 
occurred. 

Multiple resolved binding failures 
occurred. 

Name does not exist. 

Stale repository entry accessed. 

Name collision exception occurred. 

Lookup attempt failed. 

Service failed. 

Name Frame failed. 

Invocation failure occurred. 

Invalid name detected. 

Remote failure occurred. 

Exporter failed. 

All other exceptions. 
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There are two aspects to threading when programming with J-SEI. 

• The threads that the service handler uses to handle requests to the service 

• The threads in the client program that may share a connection to the core. 

When service providers create services, they create service handlers. These service 
handlers can be set up so that there are many threads that handle requests to this 
service. Essentially, each service handler comes with a ESThreadPoolManager that 
manages the pool of threads for servicing requests to this service. Furthermore, 
there are two main policies that can be used by the service provider: 

• Thread per request: When the configuration indicates that the service provider 
wants to spawn off a thread per request, the ESThreadPoolManager creates a 
new thread to handle every request for the service. This thread runs to 
completion at the end of the request. 

• Fixed thread pool: In this case, the thread pool manager has a fixed pool of 
threads that depends on the number of threads that the client has indicated in 
the ESServiceHandler. The client can set the number of threads she wants by 
using the setNumThreads(int num) in the ESServiceHandler. 
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Client applications in can be multithreaded. A Client can choose to create a 
connection to the Core and then create multiple threads (using the native Java 
threads) that use this connection simultaneously. 



Figure 16 An example of threads 

Because these threads share the same connection, any state stored in 
ESConnection is shared across all these threads. In certain situations, this is 
undesirable when the threads need to operate independently of each other. 
ESThread is used in these situations. 

An example of where this problem can occur is the use of the 
se tCurrentFolder ( . . ) API, to set the current folder in which new bindings are 
created. If multiple threads need to change the working directory without affecting 
other threads, then these threads should be created using an ESThread ( ) call, 
which clones the ESConnection state on creation of the thread. 

Just like Java Threads, there are two ways of using the J-ESI threads. 

• Application developer creates a Java file which implements ESRunnable 
(counterpart of Java Runnable) and passes this to the constructor of 
ESThread (counterpart of Java Thread). The application developer does this 
if his Java file already extends some other Java class and hence could not extend 
ESThread directly. This is the suggested and preferred way of using ESThreads. 
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ESThread threadl = new ESThread (esrunnable) ; 
threadl . start ( ) / 

Application developers can also extend ESThread directly. An example is as 
shown below. 

piiblic ApplThread extends ESThread 

{ 

public ApplThread {ESConnect ion coreConnection) 

{ 

super (coreConnection) ; 

} 

public void rm{) 

{ 

ESConnect ion clonedConnection = 
super .get Connect ion {) ; 



clonedConnection. get ServiceContext () . 
set Current Folder (...); 

} 

} 

For example, the following code fragment creates two threads that operate on the 
same connection: 

piiblic class ThreadTest 

{ 

public static void main{String args[]) 

throws ESInvocationException, ESLibException, 
Interrupt edExcept ion, lOException 

{ 

String propertyFileName - new String {" /users/connection. prop" ) ; 
ESConnection coreConnection = new SS Connect ion (propertyFileName) ; 
ApplThread threadl - new ApplThread (coreConnection) ; 
ApplThread thread2 = new ApplThread (coreConnection) ; 
threadl . start ( ) ; 
thread2 . start ( ) ; 

} 

} 
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E-speak Clients discover Services and interoperate with them using a remote object 
model or using Events. In addition to these approaches, e-speak supports a purely 
messaging interaction model v^ith the ESServiceMessenger class. 

Chents send and receive messages using synchronous or asynchronous messages 
to other Services represented by the ESAccessor associated with the Service. 

ESServiceMessenger messenger ^ 
new ESServiceMessenger {core Connect ion) ; 

The messenger can be used to send a payload object synchronously or 
asynchronously to any other Service. To send an object, use the following code: 

Ob j ect payload = new Ob j ect ( ) ; 

ESService myService = finder. find (query) ; 

ESAccessor serviceAccessor = ( (ESAccessorHandle) myService). 

getAccessor ( ) ; 
Object retValue = messenger . sendSynchronous 

(serviceAccessor, (Object) payload) ; 

or (to send asynchronously) : 

ESMessage msg = messenger . sendASynchronous 
(serviceAccessor, (Object) payload) ; 

When an asynchronous message is sent, a message ID is returned in the form of an 
ESMessage. The service sending an asynchronous message may expect a 
notification to be returned. It can wait for a reply using the wait method as follows: 

messenger .wait (msg) ; 

where msg is the return value of the asynchronous send. 
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A Service expecting to receive messages can instruct tlie ESServiceMessenger 
to receive messages destined for a particular service element by using the following 
code: 

ESMessage msg - messenger . receive (se) ; 
where se is an ESServiceElement which has been initialized and registered. 

On receipt of a message, a Service can extract its payload, operate on it. To extract 
the payload from the ESMessage, use the following method: 

Object obj = msg. get Payload 0 ; 

On operating on the payload, the service can reply to a message by invoking the 
reply 0 method on it. 

Object repObject - new ObjectO; 
msg.reply (repObject) ; 
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The purpose of ESIDL compiler is to prepare the code that enables programmer of 
client code to invoke services as if they were running in the same process space. 
Such code includes stub, registering into message registry and serialization of 
objects. 

ESIDL compiler can create new code and check existing code for conformance. 
Both e-speak serialization and Java serialization are supported. 



Generating code 

ESIDL compiler uses as input description of services, types, and exceptions and 
creates support files needed by user to invoke service through e-speak. 

There are two kinds of description: 

• services are described in service description files 

• types and exceptions are described in type description files. 
There are several kinds of support files: 

• interface files that define service interfaces 

• stub files that represent service on client side 

• message registry files that are used to register classes with e-speak messaging 
layer 

• class files that implement data types and exceptions 
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Data type description can be in an ESIDL file (extension ".esidl") or in a Java file 
(extension "java'). Service description can be only in an ESIDL file. ESIDL files are 
checked and new code is generated from them. If files of both types exist, then the 
ESIDL file is used as input 

Processing Java files is new to ESIDL compiler. 



Service description includes information about an e-speak service. For ESIDL 
compiler every parameter it receives on the command line denotes an e-speak 
service. This is a change from the previous version where all service files and data 
types had to be listed. Interface file, stub file, and message registry file are 
generated for every e-speak service. 

Service, esidl E Servicelntf . java, ServiceStub. java, 
ServiceMessageRegistry . j ava 



Type description includes information about: 

• types of service attributes 

• types returned by service methods 

• parameters to service methods 

• exceptions thrown by service methods 

Type description files are not listed as command line parameters to the compiler. 
They are searched for using import statements in the same manner as javac 
compiler searches for the source files (CLASSPATH environment variable or 
-classpath option). 



Input Files 



Service 



Description 



Type Description 
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Type.esidl -> generated Type.j^va 
Type.java -4 checked Type.java 



Output 



Files 



Interface 



File 



Interface file includes interface that the service implements. The interface extends 
ESService. 



Stub file includes code for: 

• serialization of service stub object 

• rerouting of service method invocations through core 

• calling messaging registry initialization (in message registry file) for return 
types, parameter types and exception types used in the service 



Message registry file includes code for registering types (for a list, see Type 
Description chapter) with MessageRegistry. 



Type file is generated from type description. Serialization code is generated (for 
.esidl files) or checked (for java files). E-speak serialization is default if none is 
specified (in declaration of type). Otherwise the specified serialization is used. 



Stub File 



Message Registry File 



Type File 
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Command Line Parameters 

Do not list all data type and exception files as the compiler parameters as it was 
required by the previous version of the compiler. 

Java net . espeak.util . esidl . IDLCompiler [-classpath] cp <path-to- 
sources>] [-verbose] <service-desc> [<service-desc> ...] 

where: 

Semicolon separated list of directories where compiler 
searches for description files. (dot) is used for current 
directory. If classpath is not specified, environment 
variable CLASSPATH is used. 

Instructs the compiler to print out information about 
created files. 



<path-to- 
sources> 



-verbose 



IDL Requirements 

Requirements have changed from the previous version and are now much less 
strict. 

Description in ESIDL file 

Service description is admissible if: 

• it is declared pub lie AND 

• all methods it declares are admissible 

A user-defined abstract class or a user-defined exception is admissible if: 

• it is declared pub lie AND 

• its parent type is either j ava . lang . Ob j ect or another admissible user- 
defined data type 

A service method is admissible if: 
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• return type and parameter types are admissible 

• exceptions thrown are admissible 

Description in Java file 

A user-defined data type (a Java class) must conform to these additional 
restrictions: 

• implements ESSerializable or java . io. Serializable interface 

A user-defined exception (a Java class) must conform to these additional 
restrictions 

• it must extend ESServiceException 

A service method is admissible if it throws ESInvocationException 
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J-ESI provides simple mechanisms for service providers and clients to monitor 
accesses to their services. Service providers can use these mechanisms to either 
generate management events such as billing events, create an access log, or provide 
mechanisms for performing load balancing, redirecting requests should a particular 
server be unavailable, etc. Clients can use interceptors for adding or removing 
parameters from requests or even implement a secure invocation interceptor that 
finds an available service with the required method and invoke it. 

In essence, each ESServiceElement object contains an ESIceptorControl object 
that controls the list of interceptors associated with the service element. The 
interceptor objects are instances of classes that extend the abstract ESIceptor 
class. The ESIceptorControl object therefore provides methods provides methods 
to add and remove interceptors from the ESServiceElement. When a message 
arrives for the service represented by the ESServiceElement, the message is passed 
through each interceptor that the service provider has associated with the 
ESServiceElement. 

Interceptors are classified based on whether they are terminal or not. A terminal 
interceptor is an instance of ESTerminallceptor, and represents an actual 
invocation to the service. There is a single terminal Therefore, the ESIceptorControl 
that is associated with any ESServiceElement, comes with a default 
ESTerminallceptor However, the service provider can change that terminal 
interceptor with any other terminal interceptor that she writes. 

The service provider must go through the following steps in order to set up an 
interceptor: 

• Define an interceptor class that extends ESIceptor or ESTerminallceptor. The 
service provider must implement the invoke (ESReque St req) methodinthe 
extended class. Furthermore, if the interceptor being defined is an extension of 
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ESIceptor, she has to make a invokeNext ( ) call in the implementation of the 
invoke method. If this is not done, the interceptors that are added after this 
interceptor are not invoked. 

• The service provider also must implement the initialize (Obj act 

pa rams ) method in the interceptor class. This method is invoked when the 
interceptor is added to the Esicept or control and can be used to initialize the 
state of the interceptor. 

• When the service provider creates a ESServiceElement that represents the 
service, she makes an addlceptor (ESIceptor icp, Object params) 
that adds the interceptor to the interceptor control object associated with the 
service element. 

The service provider is free to override other methods in Eslceptor, but the invoke, 
and initialize methods must be implemented. 

We now present a simple example that shows using the interceptors. Consider the 
print service example from the previous sections. Suppose the service provider 
wants to: 

• balance the load among multiple print service implementations 

• generate information about each access to the print service 

This is accomplished by the following interceptors: the LoadBalancinglnterceptor, 
and the Printinglnterceptor 

pxiblic class LoadBalancinglnterceptor extends ESIceptor { 
/ / Array of backup services 
private ESService[] services; 
private ESService thisService; 

//If the service reaches this load backup services are invoked 
private int LIMIT_LOAD 5; 
private String PRINT ~ "print"; 

public boolean invoke {ESRequest req) { 

System. out .print In ("LoadBalancinglnterceptor enter invoke"); 
if (req.getMethodNameO . equals (PRINT) ) { 
try{ 

ESRequest request = new ESRequest ( ) ; 
// check services load 

int load = ( (Print Servicelntf) thisService) .getLoadO ; 
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if (load > LIMIT_LOAD) { 

// the load is above limit load, invoke backup service 
int rainLoadService = getLowestLoadService C ) ; 
PrintServicelntf ps = (PrintServicelntf) services [minLoadService] ; 
req. setReturn Value {ps. print { (String) req.getParamValue ( "argO " ) ) ) ; 
invokeNext ( req) ; 

}else{ 

invokeNext (req) ; 

} 

} catch (Except ion e) { 
return false; 

} 

}else{ 
try{ 

invokeNext (req) ; 
} catch (Exception e) { 

} 

} 

return true; 

} 



public void initialize (Obj ect param) { 

// .. implementation that initializes the services array, etc. 
/ / from information in param 

} 

private int getLowestLoadService () { 
//.., implementation 

} 

} 

//This is how the interceptor code looks like 

public class Print inglnterceptor extends ESIceptor { 
int cnt=0; 

piiblic boolean invoke (ESRequest req) throws ESInvocationException{ 
if (req.getMethodNameO .toStringO . equals ( "print" ) ) { 
cnt++ ; 

writeCountToLogFile 0 ; 

} 

try{ 

invokeNext (req) ; 
} catch (Except ion e) { 
} 
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return true; 

} 

private void writeCoxmtToLogf ile ( ) { 
/ / iinplementation 

} 

public void initialize (Object param) { 

} 

} 

Now that we have defined the two interceptors, the print server, looks as 
follows: 

pxiblic class PrintServer 

{ 

public static void main {String [] args) 
{ 

try { 

String propertyFileName = new String { "/users/connect ion. prop" ) ; 
ESConnection coreConnection = new ESConnect ion (propertyFileName) ; 
ESServiceDescription printDescription = 
new EServiceDescription( ) ; 

printDescr ipt ion. addAt t r ibute ( ''Name" , "printer" ) ; 
ESServiceElement printElement = 

new ESServiceElement (coreConnection, printDescription); 
printElement . set Implementation {new Print erServicelmpl () ) ; 
printElement . register () ; 

printElement .addlcep tor (new Printinglnterceptor () , "HP Lobby 49 U 
printer" ) ; 

LBIParams IbiParams = ..// initialize object expected by 
//initialize method of LoadBalancinglnterceptor 
printElement . addlceptor (new LoadBalancinglnterceptor ( ) , 

IbiParams) ; 
printElement . start ( ) ; 

System. out .println ("Started printer Service ") ; 

} 

catch (Exception e) { 
// handle the exception 

} 

} 

} 

In the above example, the printing interceptor is Invoked before the loadbalancing 
interceptor on any request. If the service provider wants the order to be reversed, 
reverse the order of adding the interceptors to the service element. 
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The Account Manager allows administrators to create and manage accounts in e- 
speak. This means that administrators can create accounts, grant or change 
permissions for accounts, and occasionally delete accounts. In the current release, 
the Account Manager cannot grant, change or revoke account permissions, but this 
will be added in a future release. 



Programming Model 

The Account Manager module provides three basic abstractions, the Account 
Manager, the Account Profile, and the Account Description. The Account Manager 
allows basic account management functions, including creating and deleting 
accounts, authenticating users, and retrieving lists of accounts. Each account 
created by the account manager has an account profile associated with it, which is 
required for authentication of the account. To change die description associated 
with the account profile, a profile description with a valid (non-null) vocabulary 
must be supplied, together with the attributes to be added to the description. 

Profile Description 

The Profile Description describes attributes of the Account Manager. Since the 
default Account Manager vocabulary does not define a set of attributes that are 
expected, the user must provide a vocabulary that describes the attributes which 
will be included in this profile description, so that it can be added to the existing 
description of the account profile. In the account manager module, this abstraction 
is represented by the ESProf ileDescription class. 
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Account Profile 

The Account Profile contains the authentication information for the account. It is 
initialized with just the account name and password phrase and can be modified by 
adding a Profile Description to it. In the account manager module, this abstraction 
is represented by the ESAccountProf ile class. 

Account Manager 

The Account Manager allows the service administrator to perform administrative 
tasks such as creating and deleting accounts, retrieving lists of all accounts, and 
adding descriptions to existing accounts. The service administrator s main 
interaction to the Account Manager module is through the Account Manager 
abstraction itself. In the account manager module, this abstraction is represented 
by the ESAccountManager class. 

In this release, there are two default accounts defined in e-speak s core Account 
Manager: the admin account, and the guest account. The username, passphrase pair 
for the admin account is "admin, admin", and the corresponding pair for the guest 
account is "guest, guest". 



A Simple Example 

Consider an example where a service administrator decides to create an account 
temporarily, change its description, and then delete the account. At present, only an 
administrator or someone presenting the credentials of the account itself can delete 
an account. In a future release, there will be functionality allowing the granting of 
permissions to new accounts, and it is probable that some new accounts will be 
granted permissions to delete at least some subset of the existing accounts. 

First, to create the account, the service administrator should open a connection to 
an e-speak core. (The core is already running). After a connection has been 
established, its getAccountManager { ) method can be used to retrieve the active 
ESAccountManager. The ESAccountManager can now be used by the 
administrator to perform normal account maintenance activities. 
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string propertyFileName = new String ( "/users/connection. prop") ; 
ESConnection esconn = new ESConnection (propertyFileName) ; 
ESAccountManager acctMgr = esconn .getAccountManager () ; 

Now that we have retrieved the ESAccountManager, the administrator can create 
an account based on an account name. First, an ESAccountProf ile must be 
created using that account name. The newly created ESAccountProf ile is 
passed in as the associated profile for the account to be created. 

ESAccoiont Prof ile acctProf = new ESAccountProf ile ( "testAccount") ; 
String acct - acctMgr .createAccount (acctProf ) ; 

The account just created can be referred to by the j ava . lang . String returned 
from the creation. The administrator can now add a description to the account. To 
do this, he/she must first ensure that there is a valid vocabulary associated with it, 
then must create an ESProf ileDescription and add attributes to it that 
describe this ESAccountProf ile. 

ESVocabularyDe script ion vocDesc = new 
ESVocabularyDescription { ) ; 

vocDesc.addAttribute (ESConstants .SERVICE_NAME, "testVocab") ; 
vocDesc.addStringProperty ( "manufacturer" ); 
vocDesc .addStringProperty ( "model" ); 
vocDesc.addStringProperty ( "year" ) ; 

ESVocabularyElement vc = new ESVocabularyE lament (esconn, 

vocDesc ) ; 

ESProf ileDescription desc = null; 
ESAttribute [] atts = null; 
ESVocabulary vocab - null; 

try { 

vocab = vc . register 0 ; 
} catch (NameCollisionException nee) { 

nee .prints tackTrace ( ) ; 
} catch (ESLibException esle) { 

esle .printStackTrace { } ; 
} catch (ESInvocationException esie) { 

esie. printStackTrace 0 ; 

} 

desc = new ESProf ileDescription (vocab) ; 
desc . addAttribute { "manufacturer" , "Honda" ) ; 
desc. addAttribute ("model" , "Civic") ; 
desc. addAttribute ("year" , "2000") ; 
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try{ 

acctMgr-addDescription{acctProf , acct, desc) ; 
} catch (ESInvocationException esie) { 
esie.printStackTrace (} ; 

} 

Now that there is an active account, with an account description^ the properties just 
described in the ESProf ileDescription can be used to find this account again. 
To do this, an ESQuery is constructed, describing the value desired for the attribute 
in question, and this query is used as the argument to a find ( ) operation in an 
ESServiceFinder. This retrieves the hst of services (accounts, in this case) that 
satisfy the requirements of the ESQuery, and then the service administrator can 
switch to this account using the switchAccount ( ) method of the active 
ES Conne c t i on. 

ESServiceFinder finder = new ESServiceFinder (esconn) ; 
try { 

ESQuery query = 

new ESQuery (vocab, 

" (manufacturer == 'Honda') or (year == '2000*)"); 
ESService[] serviceList = f inder . find (query) ; 

ESAccessor accessor = ( (ESAccessorHandle) 
serviceList [i] ) . 

getAccessor () ; 

esconn. switchAccount (accessor) ; 

esconn. init () ; 
} catch (LookupFailedException Ife) { 

Ife.printStackTraceO ; 
} catch (ESInvocationException esie) { 

esie .printStackTrace 0 ; 

} 

NOTE: The core finder assumes that a single char in single quotes is of type char and 
multiple characters in single quotes are of type String. If use a single char constraint 
for an attribute of type String the single char should be enclosed in double quotes 
and them it is interpreted by the core as string type. 
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The service administrator can also change to the account simply by creating a 
property file that describes the attribute and its value, and using that property file 
to create a new ESConnection. The following code snippet shows this method of 
changing to an account that has had an ESProf ileDescription added to it. 

Properties prop = new Properties (System. getProperties) ; 
prop. put ( "manufacturer" , "Honda" ) ; 
try { 

String propertyFileName = new String { "/users/ 
conne ct ion. prop " ) ; 

ESConnection testConn = new ESConnection (propertyFileName) ; 
} catch (ESInvocationException esie) { 

esie.printStackTrace 0 ; 
} catch CESLibException esle) { 

esle .printStackTrace ( ) ; 

} 

Multiple queries can be included in the property file, one on each line, to create a 
complex constraint for the desired account. 

If there is a need to retrieve the ESAccountProf ile of an account, for example, 
when an account has been retrieved using one of the methods described above, the 
getAccountProf ile ( ) method of the ES Ac count Manager can be used. 

try { 

ESAccountProf ile retProf = acctMgr . getAccountProf ile ( 

acctProf , acct) ; 
} catch (ESInvocationException esie) { 
esie .printStackTrace 0 ; 

} 

A valid ESAccountProf ile is required before an ESAccountProf ile can be 
retrieved. This is to prevent unauthorized access to the profiles of accounts in e- 
speak. There are currently two valid ESAccountProf iles, the profile of the 
"admin" account, and that of the account itself. No other account profiles are 
authenticated to retrieve a third account profile. 

The administrator can also set the ESAccountProf ile for a given account, to 
allow, for example, changing of the password for the account. As in the previous 
example, a valid account profile is required in order to call the 
setAccountProf ile ( ) method on an account. 

ESAccountProf ile newProf - new ESAccountProf ile (name, newPwd) ; 
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try { 

ESAccountProf ile retProf = acctMgr . setAccountProf ile ( 

acctProf , newProf ) ; 
} catch (ESInvocationException esie) { 
esie.printStackTrace 0 ; 

} 

The getAllAccounts ( ) method can be used to retrieve a list of all the existing 
accounts. This list can, for example, be useful for checking whether a particular 
account name is already used. This method can be called with no authentication 
required for the caller. 

try { 

String [] accounts = acctMgr .getAllAccounts {) ; 
} catch {ESInvocationException esie) { 
esie .printStackTrace { ) ; 

} 

Finally, to delete an account, the caller must again provide a valid 
ESAccountProf ile, as well as the name of the account to be deleted. The 
account is only deleted if the provided ESAccountProf ile can be successfully 
authenticated. 

try { 

acctMgr .deleteAccount {acctProf, acct) ; 
} catch (ESInvocationException esie) { 
esie .printStackTrace ( ) ; 

} 
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Introduction 

This document describes the current basic setup for using e-speak securely. 
Security is subtle and it is dangerous to treat it as just another thing to "select the 
check box". 

This is the first release of e-speak with security and inevitably there are many 
practical issues relating to how e-speak enabled services and clients make effective 
use of security. These deployment issues will be discussed and decisions taken over 
the coming months. Hence, this initial release of secure e-speak is mostly 
concerned with basic deployment of the security architecture itself. After the 
architecture is deployed, the security is ready to be activated to enforce particular 
security properties as necessary. 

There are three main sections to this appendix. The first deals with the basic 
aspects of the security model, and in particular PSE's and certificates. The second 
section then discusses a bootstrap process used for testing purposes. The third and 
final section discusses security configuration files. 

The Basic Security Model 

A thumbnail sketch of the security model goes as follows: 

Everyone (and everything) has a set of public/private keys. Entities are distributed 
and interact with one another by means of secure sessions using the SLS protocol — 
this includes firewall traversal technology. All entities can both use services offered 
by others and also provide services to others. This means that all parties in secure 
sessions have to be authenticated to each other. In particular, SLS secure sessions 
authenticate both parties involved by using challenge-response negotiations based 
on public-key cryptography. 
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Access control to services is done by exchanging digitally signed certificates as a 
part of the SLS protocol providing secure sessions. These certificates act like 
"tickets" that grant entities with authorization to access and make use of services. 
Certificates are signed by issuing entities (or Principals) and are issued to subject 
principals who may use them. These certificates can also be chained together (using 
delegation) to give composite authorizations. 

Refer to the E-speak Architecture Specification chapter on "Access Control" for 
further details concerning the security model 

PSE's and Certificates 

A Private Secure Environment (PSE) represents a keystore containing public/ 
private key pairs. Each principal e-speak entity needs to have their own set of keys 
and thus needs to store them securely within a PSE. The PSE itself can be stored as 
a binary file in your local file system. This data is encrypted and a passphrase is 
required to lock/unlock the data it contains. 

The PSE is responsible for generating it s own key pairs — in particular, it has been 
designed so that private keys should never be exposed i. 

The other main function of a PSE involves validating and signing certificates. 
Validating a certificate involves checking the signature of the certificate using the 
issuers public-key (embedded within the certificate) . Signing a certificate involves 
using a private key held within a PSE to create a digital signature, based upon a 
message digest of the certificate data. 

PSE Manager 

The PSE Manager is a GUI tool that supports these basic tasks: 

1 Creating a new PSE and saving it as a binary file. 

This involves selecting a passphrase that is used as an encryption/decryption 
key. It is important to keep this passphrase information secure — anyone 
capturing your PSE can /?er/ec^masquerade as you and access everything that 
vnii ran arrp^ts^; ARo ln<;ina or fnrapttina vnnr na<;';nhrp<gp mppn<: that von ;^rp 

1 There is currently a method that can expose private keys - but this is only temporarily present 
to accommodate a deprecated internal interface that soon it is unnecessary to support. 
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unable to unlock or access your own PSE. For automatic operation, the PSE 
passphrase can be kept in a pass file stored on a floppy disk etc. There is a 
configuration option for this. 

2 Creating new keys-pairs. 

The PSE Manager can create new key-pairs, each of which are given a symbol 
label. These labels can then be used when constructing certificates. Note that 
this labels are referred to as roles in espeak.cfg and some of the security code. 

3 Creating and editing certificates. 

Attribute certificates typically contain information about the issuer, the subject, 
what is being authorized and the validity period. For convenience, the PSE s 
symbolic labels (or role^ for keys can be used to refer to known keys when 
constructing certificates — thus avoiding tedious and error-prone data entry of 
key information. 

4 Validating and signing certificates as described above. 

PSE data can be saved to binary files (using a passphrase for the encryption key) 
and certificates can be saved to text files etc. 

For further information on the PSE Manager, refer to the PSE Manager user 
documentation. 



Bootstrap process for testing 

The bootstrap process for testing purposesis as below. When writing and deploying 
secure applications, refer to the J-ESI documentation and the E-speak Architecture 
Specification. 

1 Use the PSE Manager GUI tool to do the following: 

a Generate a keystore object (i.e. a Private Secure Environment) and is typi- 
cally called securestore . txt. This is presently shared by all partici- 
pants—the core, the client and the service. Therefore, this configuration is 
77^^ distributed. 
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b Each participant has their own key-pairs. The current simple approach is to 
generate three different key-pairs, one for each participant, with the follow- 
ing labels : client, core, and service, all within the same PSE. 

c Generate a basic attribute certificate, one for each pair of distinct partici- 
pants (i.e. client as issuer, core as subject and so on for all distinct combina- 
tions) which gives each participant arZ)t/Yra/7 permission to perform 
operations. The PSE Manager can be used to conveniently generate these 
attribute certificates— it has access to all the keys that were generated. The 
PSE labels associated with the key-pairs can be used to refer to the keys 
within the certificates for convenience. 

d After it is generated, the important thing is that the certificate must be 
i55£/et/— this means it is signed hy the Core itself. Thus, the certificate is 
issued by the Core, and having the Core again as its subject, with an all- 
powerful e-speak tag attribute: 

(net .espeak .method (*) (*)) 

Again, the PSE Manager can perform this function of signing these certifi- 
cate by any one of the participants. 

Significantly, the PSE Manager GUI tool is generally standalone and does 
not need any prior configuration, i.e., it does not require any configuration 
before it can be used. 

2 To operate the core with security turned on, a security configuration file needs 
to be correctly loaded containing the appropriate attributes. The configuration 
file is more fully explained in the following sections. But a high-level snapshot 
goes as follows: 

a The configuration file is like a Java properties file and is typically named 
espeak . of g. It is searched for in the current directory, the user*s home 
directory or on the Java CLASSPATH. 

b A very simple espeak.cfg file is shown on the next page. 



i $Id: espeak.cfg, V 1.1,2.1.4.10 2000/05/16 07:17:42 ks Exp $ 

I =.=== = = = = = = = = = i= = = = ===i = ~~~ — ~ — ~ — ~= = === = = = = =i=:=iSz:^Xz^=: = = = === = = == = = = : 

1 E-speak security properties file. 
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I Master flag controlling whether security is on or off. 
net . espeak . security . activate=on 

i Set a property prefix. 
@pref ix=net . espeak . security 

i Default name of the keys tore file 
.pse . storef ile=seGurestore . txt 

i Gui mode runs a dialog for the passphrase. 
! .pse.mode=gui 

i Passphrase mode looks for the passphrase property, 
.pse. mode = passphrase 

1 Passfile mode looks for a file containing the passphrase property. 
!. pse. mode = passfile 

I Define the passphrase. 

.pse. passphrase = default passphrase 

I Define the default role (i.e. the default PSE key label), 
i. pse. role = client 

The following section discusses configuration files in more detail 



Configuration files 

The default configuration file is espeak.cfg. The file is looked for in the following 
places: 

• config directory under e-speak home as defined by property 'espeak_home* 
directory specified by property 'netespeak.util.config.file', or current directory 
(from system property 'user.dir') if the property is not set directory specified by 
'user.home' system property as a system resource from the classpath Java 
system properties can be set on the Java command line using the syntax - 
Dproperty=value. 
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• The name of the file to look for can be specified using the 
'netespeak.util.config.flle' property. The file defined by the property 
'netespeak.util.config.master'is always loaded on top of ail other files, if 
specified. The default for this property is null 

• All files found are loaded, in reverse order, with files found earlier being merged 
on top of properties from files found later. The format of the files is Java 
properties file format, with the following additions. 

@pref ix=<pref ix> 

This sets a property prefix to apply to properties starting with a dot. For example: 

©pref ix=net . espeak . security 
.pse.mode = passphrase 

results in net . espeak . security . pse . passphrase being set to passphrase*. 
After it is set, a prefix remains in force until changed or set null. 

©mode = <mode > 

If the <mode> is "override** (default) the values found in this file is used and all 
previous values are ignored. After the espeak. cfg parser encounters a file with mode 
set to "override", no more files are parsed. If the mode is "merge" espeak.cfg files 
are combined, if two files specify values for the same property, the value in the last 
file to be parsed is used. 

The name of the configuration file to look for can be set using the system property 

net . espeak . util . conf ig . file 
which has the default value espeak . cfg. 
If the system property 

net . espeak . ut il . conf ig . master 
is set, the file of that name is loaded on top of all other files found. 
The configuration is got by calling 

Configlntf Conf ig. get Instance { ) 

which returns a reference to a static instance of the default configuration. Other 
files can be loaded directly if wanted, see util.Config for the API. Single property 
files can be loaded using ConfigProps. 
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A Java properties file contains property names and definitions. The name is 
separated from the definition by =\ Spaces before the property name and around 
the = are ignored. The value of the property extends to the end of line, and includes 
trailing spaces. Long property values can be broken across lines using \ to escape 
new lines. The characters ! and # introduce end-of line comments. The character : 
may be used as an alternative to =. 



The class util.Convert provides methods to convert property strings to and from 
common types. The types int, boolean, and long are supported. The duration 
converters accept times in the format 12h3ml.001s and convert them to longs in 
milliseconds. Any zero component of a time can be omitted, and spaces may be 
included. A zero time can be stated as Os. 

The boolean converter accepts on, true, yes for true and off, false, no for false, 
regardless of case. 



The mapping or argument switches to properties can be defined using utiLArgSpec. 
This provides methods to process command-line arguments and map them onto 
properties in a configuration. 



The following are the properties supported by the security code. 

• Master flag controlling security: net . espeak . security . activate, 
boolean, default off'. If this property converts to true, security is activated. 

• Property net . espeak , security . connectOnContact, default off, controls 
whether secure sessions are established with newly encountered resources. 
When it is off, sessions are not established unless required (by 
SessionRequiredException) or created explicitly. 



Property conversion 



Argument 



specifications 



Security properties 
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• PSE mode: net . espeak. security .pse .mode. Values: gui, passphrase, 
passfile. Default gui. If the mode is gui, a dialog is used to get the PSE 
passphrase. If the mode is passphrase the property 

net . espeak . security . pse .passphrase is used to get the passphrase 
(default null). If the mode is passfile the property 

net . espeak . security , pse .passfile (default passflle.txt) is used to get 
the name of a file which must contain a 

net . espeak . security . pse . passphrase property defining the 
passphrase. 

• PSE key file: net .espeak. security .pse . storef ile, default 
securestore.txt. Defines the name of the file containing public-private key pairs. 

• PSE role: net . espeak . security . pse . role, default client. Define the 
default role (symbolic PSE key name) . 

• PSE file protection mode: 

net . espeak. security .pse .OSf ileprotection, default true. This 
property specifies whether local OS file protection should be applied and is 
supplied purely as an aid for testing purposes. For full security protection, this 
option should not be false. 

• Certificate file suffix: net . espeak. security .pse . cert file, default 
certs.adr. The value of this property is appended to the role name to get the 
name of the certificate file to load. If the role is client the certificate file 

is clientcerts.adr for example. 

• ACL file suffix: net . espeak. security , pse . aclf ile, default acl.adr. The 
value of this property is appended to the role name to get the name of the ACL 
file (trust assumptions) to load. If the role is client the ACL file 

is clientacl.adr for example. 

• Cipher suites: net . espeak . security . cipherSui tes. The value is a list of 
cipher suites in ADR syntax. The default is to use hmac, sha-1, and 128-bit 
blowfish. 

• Public key: net.espeak.security.pse.publicKeyAlgorithm using the values 
ELGAMAL and RSA. The default is ELGAMAL. Which one is being used can be 
found using net.espeak.security.util.PublicKeyLib. Call public static String 
getPublicKeyAlgorithm ( ) to find out. 
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We support two public key algorithms: RSA and El GamaL The entire system must 
use one or the other, mixing is not supported. Public key classes are not loaded 
statically — they are loaded dynamically based on the configured algorithm. 

When El Gamal is configured, support for RSA is not be loaded, and if RSA data is 
encountered a NoSuchAlgorithmException is thrown. Which algorithm is used is 
defined by the property. 

Example espeak.cfg file 



i E-speak security properties file. 

i Master flag controlling security. 

net . espeak . security . activate^on 
user .name =" John Doe" 



i Example time value. 

foo. timeout = 12h 3m .0001s 
! Set a property prefix. 

@pref ix=net .espeak . security 

i Gui mode runs a dialog for the passphrase. 

i .pse .mode=gui 

1 Passphrase mode looks for the passphrase property, 
.pse. mode = passphrase 

1 Passfile mode looks for a file containing the passphrase property. 

1. pse. mode - passfile 
! Define the passphrase. 

.pse .passphrase = default passphrase 

i Define the default role {PSE key name) . 

i .pse .role = foo 
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Appendix G Firewall Traversal 



This chapter discusses firewall traversal using e-speak. We present how services 
can be accessed using e-speak while sitting behind a firewall. The proposed solution 
does not require modification of the existing security infrastructure.This offers a 
fast deployment but does not provide maximum security at the boundary. 



Architecture 

The architecture of the security system is presented in Figure 17. This architecture 
is very classic, the service is connected to the Engine Inside. The Engine Outside act 
as a proxy in the DMZ for the Engine Inside. Connections are established to the 
Engine Outside and then messages are routed to the Engine Inside. 

E-speak offers end-to-end security so the number of engines relaying messages is 
irrelevant. The security (Confidentiality, Integrity and Authentication) is 
established between the services and the clients. 




Service 
JESI 



^ ► 

' DMZ 



Figure 1 7 Security Architecture 



Developer Release X.03.03.00, September 2000 



163 



Architecture 



Firewall Traversal 



When the service connects to the Engine Inside, it registers its metadata with the 
engine and establishes an outbound connection to the Engine Outside and exports 
this metadata. 

Firewalls usually offer means to establish outbound connections. HTTP proxies are 
one of them. They are widely deployed and offer through the HTTP Connect method 
a way to establish TCP connection to external systems. SOCKS V4 servers offer the 
same functionality but support stronger authentication mechanism. 

In order to achieve fast deployment of services with minimal architectural changes 
on the boundary, e-speak can be configured to use HTTP proxies or SOCKS servers. 

The requirements on the service provider side are as follows: 

• An HTTP proxy or SOCKS server must be present in the firewall. 

• A system in the DMZ must host an e-speak engine (Engine Outside) . 
The requirements on the client side are as follows: 

• An HTTP proxy or SOCKS server must be present in the firewall. 

The HTTP proxy approach is possible only if the proxy allows for the HTTP 
Connect method on the Engine Outside port. 

These approaches uses either SOCKS V4 or HTTP Proxies to allow inbound 
connection. SOCKS V4 and HTTP Proxies have been created explicitly for outbound 
connections. Therefore these approaches have some drawbacks. Firstly, the service 
is available from the outside as long as the connection to the Engine Outside is up. 
This requires the connections to be long-lasting. Secondly, there is no control at the 
boundary because the Engine Outside is not capable of such functionality. The 
authentication and authorization is done at the service end-point, this means that 
unauthorized messages can potentially be sent to the inside services. 
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Deployment using HTTP proxies 

Figure 18 and Figure 19 presents classic deployment configuration using e-speak. 
Qnpar^A QnporyB 




Figure 18 Client connecting directly to the Engine Outside 

In this scenario, the client connects directly to the Engine Outside through J-ESI. 
Follow these steps: 

1 Setup the client espeakxfg file with the following properties: 
netespeakinfra.cci.messaging.webproxyname=<proxy name> 
netespeak.infra.cci.messaging.webproxyport=<proxy port> 

This explicitly tells the client to open a connection through the web proxy, 

2 Setup the Engine Inside espeakxfg file with the following properties: 
net.espeak.infra.corexonnectorwebproxyname=<proxy name> 
net.espeak.infraxorexonnector.webproxyport^<proxy port> 

3 The service needs to explicitly export itself to the Engine Outside using its 
RemoteServiceManager. 
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Figure 19 Client connecting to the Engine Outside using a local engine 

In this scenario, the client connects to a local engine, which in turn connects to the 
Engine Outside. 

Follow these steps: 

1 Setup the Client Engine espeak.cfg file with the following properties: 
net.espeak.infra.core.connector.webproxyname=<proxy name> 
net.espeak.infra.core.connector.webproxyport=<proxy port> 

2 Setup the Engine Inside espeak.cfg file with the following properties: 
net.espeak.infra.core.connector.webproxyname=<proxy name> 
netespeak.infra.core.connector.webproxyport=<proxy port> 



its 



3 The service explicitly exports itself to the Engine Outside using 
RemoteServiceManager. 

4 The client explicitly imports the service from the Engine outside using its 
RemoteServiceManager. 

NOTE: As explicit import and export are awkward, another alternative is to run an 
advertising service in the DMZ attached to the Engine Outside and use it to do the 
import and export implicitly. With this modification, the above scenario changes as 
follows: 



1 



setup the Client Engine espeakxfg file as above. 
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2 setup the Engine Inside espeakxfg file as above. 

3 The service is advertised in the advertising service in the DMZ. This leads to an 
implicit export from the Engine Inside to the Engine Outside. 

4 The client finds the service by looking up in the DMZ advertising service. This 
leads to an implicit import from the Engine Outside to the Client Engine. 

The scenario in Figure 19 can be modified similarly. 



Deployment using SOCKS Server 



The SOCKS protocol is supported internally by the VMs. No specific configuration 
is needed except for the VM configuration itself. 

Figure 20 shows one scenario where the SOCKS servers are used by the client and 
the service provider. 



CcnpanyA 



GonpanyB 




Connector 



Figure 20 Using SOCKS servers 



In some deployment cases, it is possible that installing the Engine Outside in the 
DMZ is perceived as too complicated or impossible. 
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E-speak introduces a new way for service providers to reach service consumers. 
The connector is the central point of the system. The connector is the Engine 
Outside moved in a DMZ of a trusted party. 

Figure 21 describe the deployment scenario for the connector. 
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Figure 21 Deployment of a connector in a trusted party's DMZ 

Company C is a trusted by Company B to host its services' metadata. When 
Company B wants to expose its services to the outside, it connects the Engine 
Inside to the Engine Outside (Connector) and exports the description of the 
available services. 

When the clients wants to access a service, its connect to the connector and search 
for the given service and interact with it transparently. 

Clearly Company C needs to be trusted by the service provider because it exposes 
the service to the outside world. 

An example of the connector is the e-service village where service providers and 
services consumers can meet and establish relationship. 
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Appendix H Management 



Currently system management in e-speak is undergoing a transition from a 
traditional network object model to a document exchange model. Infrastructure 
and support for this model is still being developed and collaboration between 
parties on conmion schemas and mechanisms is in the early phases. This document 
therefore is very much work in progress and will remain as such until a variety of 
inter-related elements within e-speak become available and reach stability. 



Introduction 

This appendix describes the infrastructure and general philosophy of how web 
based management tools and an XML management interaction framework are 
provided in e-speak. 

System Management in e-speak currently consists of four things: 

• A managed service model 

• XML Schemas and dialogs that enable management. 

• Client support for making services manageable, 

• A set of tools that provide access to the management services from the web. 

This document describes the first, third and fourth of the above with code 
examples. 
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Managed Service Model 

The managed service model is simply two concepts that underpin the manageability 
of e-speak services and e-speak clients: 

• Managed State: a defined service state embodying the life cycle of a service, 

• Managed Variable Table: sets of values that can be affected by a manager for the 
purposes of configuration and control. 

For this generic model to be useful, a client must map its service specific behavior 
onto this model and expose this model to a management agent. As we see later, the 
life cycle in the managed service model has many states, including initializing, 
ready, and running. It is entirely up to the service writer how these states are 
related to the service specific behavior. 

For example a service might have no need of an initialization phase but must 
instantaneously pass this state to conform to the model. A service may also be in 
various operational states while running, but running \s the only way to express its 
condition from a management point of view. 

In summary then, the managed service model embodies a view of service behavior 
that is potentially common to many services. Therefore some custom management 
agents must deal with issues of service behavior that fall outside this model. 
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Managed Life Cycle 

The full state transition diagram is as follows: 




State Descriptions 

Initializing: The internal dynamic state of the service is being constructed, for 
example: a policy manager is being queried for configuration information and 
resources are being discovered via search recipes or yellow pages servers. When 
the service finishes this work it moves asynchronously into the ready or error 
states. 

Ready: The service is in a ready to run situation, this state is also equivalent to a 
stopped or paused state. 

Running: The service is running and responding to methods invoked on its 
operational interfaces. If an error occurs that implies that the service cannot 
continue to run, it should move into the error state. 

Error: The service has a problem and is awaiting management action on what to do 
next. 
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Closed: The service has removed/deleted much of its internal state and awaits 
either a coldReset or remove transitions. 

Inputs 

An input is the trigger that causes a state transition to occur. In any given state» 
there is a defined set of permissible inputs that are available — only those that are 
depicted in the diagram as leaving the current state and connecting with the next 
state. To attempt to perform any other transition is illegal. Note that many inputs 
can have the same name (e.g. error) but there is no ambiguity as long as the 
originating state is different. 

Clients can provide any input with impunity. However, a management agent can 
request only provide external inputs. For example, the manager can reasonably 
request that a client perform a warm reset, but not to become ready, the client alone 
can provide this input — when it's internal initialization process has completed. 

The available inputs are as follows: 

start: move into the running state. Start to handle invocations on operational 
interfaces. 

stop: move into the ready state. Stop handling invocations on operational 
interfaces. 

ready: move into the ready state having finished initialization. 

error: move into the error state, this transition is valid from any state. 

shutdown: clean up any internal state required and move into the closed state. This 
transition should not cause the deregistering of resources from the repository. 

coldReset: cause a from complete reinitialization of the service and move into the 
initializing state. The only exemption is that resources that are already registered 
should not be reregistered. 

warmReset: cause a partial reinitialization of the service — retaining some of the 
existing service state move into the initializing state. 

remove: cause the service to remove itself from existence. Any non-persistent 
resources should be deregistered from the repository. 
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Managed Variable Tables 

A managed variable table is at it s simplest a table of name/string value pairs that 
exist within the client but to which a manager has some level of access. Thus, a 
management agent can control those aspects of a services behavior that is affected 
by those variables to which it has access. 

There is a degree of configurability associated with managed variables and their 
variables that permit something more sophisticated than the simple get and set 
operations one would expect to find. 

Each table itself has a name to distinguish it from other tables. As we shall see later» 
the managed service model itself provides for two such tables. 

The most simple usage case for a managed variable would be for a variable which 
the management agent has only read access but which the client varies as 
necessary. The manager can monitor the changes (see events later) such that an 
operator who understands the meaning of this variable (e.g. 
secondsToDetonation) might gain some information. 

The next level of sophistication is to enable the operator to affect the services 
behavior by modifying the value of the variable. However, some service 
configuration is only of practical use during initialization (e.g. some resource 
allocation parameter) . Knowing the instantaneous value of such a variable does not 
explain the clients behavior (if it had been changed) and modifying it has no effect. 

To account for this, a managed variable can have one or more values. The 
compulsory value is its "live" value i.e. the value that is contributing to its current 
behavior. In the simplest case this is the only value that a variable has. 

However, a variable can have other values, which are in effect "scheduled" values 
and associated with the various reset operations in the client s life cycle. 
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For example, consider the following managed variable found in some unreasonably 
hazardous device: 



Variable Name 


Values 




Value Condition 


Remote Access 


Value 


secondsToDetonation 


Live Value 


Read Only 


42 




On Cold Reset 


Read Only 


60 




On Warm Reset 


Read/Write 


60 



Let s assume it takes some operator three minutes to reach safety or the devices off 
sv^itch. The operator brings up his management console and notices that the 
current value of secondsToDetonation is 42, and dropping. Clearly the 
circumstances are undesirable: the current value does not provide long enough to 
escape without injury. Increasing this value to three minutes or more and running 
away is ideal but the value is read only. 

Glancing down the list the operator notices that there are two reset values and 
performs a cold reset. After the device has re-booted, and re-loaded the counters 
default initial value (perhaps in ROM) it promptly starts counting down from 60 
seconds. Still not good but at least the operator can try and stay up all night 
performing cold resets every 59 seconds or less. 

Having bought some time the operator looks a little more closely at the variable. 
The warm reset value is writable. Now the operator can set this to thirty minutes 
and go and disconnect the power supply. 

Clearly a contrived example but it does demonstrate how relatively complex 
interactions between initialization, configuration value and behavior can be 
represented. 

A more likely scenario is where a client has a set of variables that configure its 
behavior that must all be changed synchronously. A management agent can modify 
its warm reset values at its leisure (being denied access to the live values) and then 
perform a warm reset. 

There is a restriction on variable table usage: 
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Uniqueness: names in a variable table must be unique within that table. It is not 
possible to implement lists by having many entries with the same name. 

Configuration Parameter Table 

The configuration parameter table is an instance of a managed variable table with a 
reserved name that identifies it as such. The table holds generic configuration data 
for the client. 

Resource Table 

The resource table is another instance of a managed variable table, identical in 
behavior to the configuration parameter table except that the names in the client's 
table refer to other services with which the client has some relationship. For 
example, if a particular client makes use of a mail service then this relationship can 
be made visible to a management agent through the resource table. Thus a 
management agent might reconfigure the client to use an alternative but equivalent 
service. While there might seem no obvious need to separate out this particular 
aspect of configuration, doing so makes it possible for a management agent to 
discover the topology and integrity of a network of connected services without the 
need for service specific interpretation of the variable table (all entries in the 
resource table are resources). 

The name used for an entry in a resource table can be any symbolic name the client 
chooses, while the value must be the valid e-speak URL of the actual service. 

System Management Events 

Events can be considered as notifications of some significant occurrence. In the 
context of system management, events must exist to convey notification of some 
change of state with regards the Managed Service Model. The following events are 
therefore defined: 

ManagedServiceStateChange: This event conveys information regarding some 
managed service state transition to any interested management agent In this case, 
the event is the name of the input provided to the management life cycle FSM. 
Clearly, the management agent must have known what the previous state was in 
order that this information be meaningful 
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ManagedVariableValueChange: This event conveys information regarding a 
value modification in a clients configuration or resource table. 



Managed Service Programmers Guide 

Writing a Simple Managed Service 

In this section we create a simple managed service 

First, to get familiar with the tools we look at the most minimal Java program that 
is "manageable** through e-speak, 

A Minimai Service 

Consider the following program: 

import 

net . e speak .management .managedservice . simpleraanagedservice . SimpleXMLManaged 
Service; 

import net . espeak. infra.cci .except ion. ESExcept ion; 
import net . espeak . j esi . management . ServiceContext ; 

public class VerySimpleExample extends SimpleXMLManagedService { 
public static final String SERVICE_NAME = "VerySimpleService" ; 
public static final String LOCALHOST = "127.0.0.1"; 
public static final int COREPORT 12346; 

public VerySimpleExample {) throws ESException { 

super (new ServiceContext (LOCALHOST, COREPORT, "tcp"), SERVICE_NAME) ; 
makeManageable { ) ; 

} 

protected void stateChangeOccurred (String transition. String oldState, 
string newState) {} 

protected void resourceChangeOccurred( String resource. String oldValue, 
String newValue) {} 

1 For reference, a fully working example of a managed service is supplied in: 
net.espeak.management.managedservice.simplemanagedservice.ExampleService 
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protected void variableChangeOccurred{ String variable, String oldValue, 
String newValue) {} 

protected boolean acceptStateChange (String transition. String oldState, 
String newState) { 
return true; 

} 

protected boolean acceptVariableChange (String variable, String oldValue, 
String newValue) { 
return true; 

} 

protected boolean acceptResourceChange (String resource, String oldValue, 
String newValue) { 
return true; 

} 

public static void main (String [] args) { 
try { 

new VerySimpleExample ( ) ; 
} catch (ESException e) { 
e .printStackTrace ( ) ; 

} 

} 

} 

VerySimpleExample (above) subclasses SimpleXMLManagedService, a utility class 
that in most circumstances provides adequate manageability support We consider 
more sophisticated examples later. 

For now let s just consider the constructor: 

public VerySimpleExample () throws ESException { 

super (new ServiceContext (LOCALHOST, COREPORT, "top"), 

SERVICE_NAME) ; 

makeManageable () ; 

} 

First, the super class is initialized with a connection to the local core^, second the 
makeManageableO method makes the service visible to any management agents. 
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Managing the Service 

We are now ready to try the program onU but first we must have a core running. For 
convenience, there is a configuration file which starts all the services required for 
management. Go to your e-speak installation directory and type: 

espeak -i config\management\xmlmanagement.ini 
After a few moments, run a web browser and go to: 
http://l 27.0.0. 1 :2000/servlet/services 
You see a screen similar to the following: 




2 For simplicity^ the host and port are hardwired into the example and assume the core is run- 
ning on the local host and uses port 12346, which is the value in the default version of xmlman- 
agement.ini. These values can be changed but the host must be the host name/IP address of a 
host running a core and the port number must match that used by the core. 
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This is a list of the visible "web enabled" services on your local core, in this case the 
services started by xmlmanagement.ini. 

Click the Service Manager link and you see the following page: 





This is the main service manager screen and displays a list of all the manageable 
services to be found on your local core. 

Note that while we call this the Service Manager, it should be remembered that it is 
clearly a web based interface onto die actual Service Manager. While the service 
manager is aware of the status of services in real time, the browser is not; so you 
should use the "Update" buttons provided to keep the display current. For related 
reasons, navigate between Service Manager screens using the links provided and 
avoid the use of the back button, particularly if you actively interacting with the 
services through the service manager. 
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Now we are ready to run VerySimpleExample. Compile the program and run it. 
After a few moments go back to the service manager screen and click the Update 
button. Now you see your program available for management: 




1 



i 

ft 



I 

m 



Click the Management link next to VerySimpleService: 
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This is the management page for your service. At the moment, your service is not 
being managed so click the Manage Service button: 
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So what does this mean? Earlier in the document we discussed the concept of the 
Managed Life Cycle of a service. If you look back at the state diagram, you see that 
the start state was initializing. Because we have not changed service state in our 
program, we remain in this state forever. 

Changing Service State 

Now let s try something slightly more interesting. Consider this next program, very 
similar to the last: 

import 

net . e speak .management . managedservice . simp leman age dservice . SimpleXMLManaged 
Service; 

import net .espeak. infra. cci .exception. ESExcept ion; 
import net .espeak. jesi .management .ServiceContext; 
import 

net . espeak .management .managedservice .managedstate .ManagedServiceStateMachi 
ne; 
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public class VerySinipleExainple2 extends SimpleXMLManagedService { 
public static final String SERVICE_NAME = "VerySimpleService2" ; 
public static final String LOCALHOST = "127.0.0.1"; 
public static final int COREPORT = 12346; 

public VerySimpleExample2 {) throws ESException { 

super (new ServiceContext{ LOCALHOST, COREPORT, "tcp"), SERVICE_NAME) ; 
makeManageable ( ) ; 

perf ormTransit ion (ManagedServiceStateMachine . TO_READY_TRANSITION) ; 

} 

protected void stateChangeOccurred( String transition, String oldState, 
String newState) {} 

protected void resourceChangeOccurred( String resource, String oldValue, 
String newValue) { } 

protected void variableChangeOccurred( String variable, String oldValue, 
String newValue) {} 

protected boolean acceptStateChange (String transition, String oldState, 
String newState) { 
return true; 

} 

protected boolean acceptVariableChange (String variable. String oldValue, 
String newValue) { 
return true; 

} 



protected boolean acceptResourceChange (String resource. String oldValue, 
String newValue) { 
return true; 

} 

pxiblic static void main (String [] args) { 
try { 

new VerySimpleExample2 ( ) ; 
} catch (ESException e) { 
e .printStackTrace ( ) ; 

} 

} 

} 

Here, the only real difference is in the constructor, where we have added the line: 
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performTransition (ManagedServiceStateMachine . TO_READY_TRANSITI 
ON) ; 

Have another look at the service state diagram and you see an internal transition 
taking the service to the Ready stzte. The line of code, above, causes this transition 
to occur. Lets compile and run this program to see what happens when viewed 
through the Service Manager. 

After the VerySimpleServiceZ is running, go to back to the Service Manager and 
click the AIJ Services link and click the Update button. Your new program is 
available for management: 






As before, go to die Services Management screen and click the Manage Service 
button. You see the following: 
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The state of your service is now listed as ready and three new buttons have 
appeared. Looking back at the service state diagram, you can see that when a 
service is in the Ready state a manager can request that it can start, stop or perform 
a warm reset. Click the Start and the following screen appears: 
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m 



Clicking the Stop button takes you back to the previous screen. All very interesting, 
but how does this relate to the program we're running? At the moment the program 
isn't affected at all by these management changes. 

Adding Custom Service Behavior 

So far the service doesn t do anything interesting, so let's take a look at how we can 
improve the situation: 

import 

net . e speak .management .managedser vice . simplemanagedservice .SimpleXMLManaged 
Service; 

import net . espeak . infra . cc i . except ion . ESExcept ion ; 
import net .espeak. jesi .management . Service Context ; 
import 

net . espeak -management -managedservice .managedstate .ManagedServiceStateMachi 
ne; 
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public class VerySimpleExampleS extends S imp leXMLManagedSer vice 
implements Rimnable { 

public static final String SERVICE_NAME = "VerySimpleServiceS" ; 
public static final String LOCALHOST = "127.0.0.1"; 
public static final int COREPORT = 12346; 
protected boolean running = false; 
protected Thread riinThread = null; 

public VerySimpleExampleB 0 throws ESException { 

super (new ServiceContext( LOCALHOST, COREPORT, "tcp") , SERVICEJ5AME) ; 
makeManageable {) ; 

performTransition(ManagedServiceStateMachine.TO_READY_TRANSITION) ; 

} 

public void run() { 
while (true) { 

synchronized (runThread) { 
if ( ! running) { 
return ; 

} 

} 

System.out.println( "Running " + System.currentTimeMillis { ) ) ; 
try { 

Thread. sleep (1000) ; 
} catch (InterruptedException e) {} 

} 

} 

protected synchronized void s tat eChangeOccurred (String transition, 
String oldState, String newState) { 

if (newState. equals (ManagedServiceStateMachine.RUNNING_STATE) ) { 

running = true; 

runThread = new Thread (this) ; 

runThread- start { ) ; 
} else if (runThread 1= null) { 

synchronized (runThread) { 
running = false; 

} 

try { 

runThread . j o in ( ) ; 
} catch (InterruptedException e) {} 
runThread = null; 

} 

} 

protected void resourceChangeOccurred (String resource. String oldValue, 
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string newValue) {} 

protected void variableChangeOccurred( String variable. String oldValue, 
String newVaiue) {} 

protected boolean acceptStateChange (String transition, String oldState, 
String newState) { 
return true; 

} 

protected boolean acceptVariableChange (String variable, String oldValue, 
String newValue) { 
return true; 

} 

protected boolean acceptResourceChange (String resource. String oldValue, 
String newValue) { 
return true; 

} 

public static void main (String [] args) { 
try { 

new VerySimpleExample3 () ; 
} catch (ESException e) { 
e . printStackTrace ( ) ; 

} 

} 

} 

Here we have given the program a runnable thread and added some code to the 
stateChangeOccurredO method. This method is called after any change of 
service state. If you compile and run this program, then when you start and stop it 
from the Service Manager you also see the thread started and stopped. 

Managing Variables 

It is also possible to manage the data within your service. Consider the next 
derivative of the service: 

import 

net . espeak . management . managedservice . simplemanagedservice . S impleXMLManaged 
Services- 
import net . espeak . infra . cc i . except ion . ESExcept ion ; 
import net .espeak. jesi .management . ServiceContext ; 
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import 

net . e speak .management . managedservice .managedstate . ManagedServiceStateMachi 
ne; 

public class VerySimpleExample4 extends SimpleXMLManagedService 
implements Runnable { 

ptiblic static final String SERVICE_NAME = "VerySimpleService4" ; 

public static final String LOCALHOST - "127.0.0.1"; 

public static final int COREPORT = 12346; 

public static final String MESSAGE_VAR = "Message"; 

protected boolean running = false; 

protected Thread runThread = null; 

protected String message = "running"; 

piiblic VerySimpleExample4 0 throws ESException { 



super (new ServiceContext{ LOCALHOST, COREPORT, "tcp"), SERVICE_NAME) ; 
createVariable (MESSAGE_VAR, message, true); 
makeManageable ( ) ; 

performTransition{ManagedServiceStateMachine.TO_READY_TRANSITION) ; 



piiblic void runO { 
while (true) { 

synchronized (this) { 
if (! running) { 
return; 



protected synchronized void s tat eChangeOccurred (String transition. 
String oldState, String newState) { 

if (newState. equals (ManagedServiceStateMachine .RUWNING_STATE) ) { 
running = true; 
rimThread = new Thread (this) ; 
runThread . start { ) ; 
} else if (runThread 1= null) { 




II 



ir 



+ 



System.currentTimeMillis 0 ) ; 



try { 

Thread. sleep (1000) ; 
} catch (Interrupt edExcept ion e) {} 



running = false; 



try { 



runThread. join 0 ; 
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} catch (InterruptedException e) {} 
runThread = null; 

) 

} 

protected void resourceChangeOccurred (String resource, String oldValue, 
String newValue) {} 

protected synchronized void variableChangeOccurred( String variable, 
String oldValue, 

String newValue) { 

if {variable. equals (MESSAGE^VAR) ) 

{ 

message = newValue; 

} 

} 

protected boolean acceptStateChange (String transition, String oldState, 
String newState) { 
return true; 

} 

protected boolean acceptVariableChange (String variable. String oldValue, 
String newValue) { 
return true; 

} 

protected boolean acceptResourceChange (String resource, String oldValue, 
String newValue) { 
return true; 

} 

public static void main (String [] args) { 
try { 

new VerySimpleExample4 0 ; 
} catch (ESException e) { 
e .printStackTrace ( ) ; 

} 

} 

} 

Here we have added a normal class variable called "message" which we print in the 
run method. What we have also done in the constructor is create a Managed 
Variable thsX informs the system manager that such a variable exists, i.e. what it's 
name is, what it s initial value is and whether it can be remotely modified: 
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createVariable {MESSAGE_VAR, message, true) ; 

This is sufficient to make the variable visible to the Service Manager, but we also 
want the our program to reflect changes to the value of this variable made by the 
service manager. To achieve this we have added some code to the 
variableChangeOccurredO method. This code simply verifies which Managed 
Variable has changed and ensures that the appropriate action is taken. In this case, 
it simply updates the local message variable. 

Viewing this service through the Service Manager looks as follows: 




1 

i 



You can see that in addition to the service state, our managed variable is visible. 
Clicking the variable name opens the following screen: 
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-3 




Here you can change the value of the variable. Try changing the value and observe 
the output of your service change while it is running. 



Dynamic Variables 

So now we can change the value of our variables remotely, but what would happen 
if we changed the value locally? If the management system is to know the state of 
your service from second to second then obviously it needs to be told. This next 
example uses an additional managed variable, which is updated locally: 

import 

net . e speak .management .managedser vice . simplemanagedservice . SimpleXMLManaged 
Service; 

import net .espeak. infra. cci . exception. ESExcept ion; 
import net .espeak. jesi .management .Servi ce Context ; 
import 

net . espeak . management . managedservice . managedstate . ManagedServiceStateMachi 
ne; 
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import java.util .Date; 
p^2blic class VerySimpleExampleB extends S imp leXMLManagedSer vice 
implements Runnable { 

public static final String SERVICE_NAME = "VerySimpleServiceS" ; 

public static final String LOCALHOST = "127.0.0.1"; 

public static final int COREPORT = 12346; 

public static final String MESSAGE_VAR = "Message"; 

public static final String TIME_VAR = "Time"; 

protected boolean running = false; 

protected Thread runThread = null; 

protected String message = "riinning"; 

public VerySimpleExampleS 0 throws ESException { 

super (new ServiceContext (LOCALHOST, COREPORT, "tcp") , SERVICE_NAME) ; 
createVariable (MESSAGE_VAR, message, true); 
createVariable(TIME_VAR, new Date O.toString (), false); 
makeManageable 0 ; 

perf ormTransition (ManagedServiceStateMachine .TO_READY_TRANSITION) ; 

) 

public void run{} { 
while (true) { 

synchronized (this) { 
if ([running) { 
return; 

} 

System. out .println (message + " " + 
System. currentTimeMill is 0 ) ; 

super. setVariable(TIME_VAR, new Date O.toString 0); 

) 

try { 

Thread. sleep (1000) ; 
} catch (InterruptedException e) {} 




protected synchronized void stateChangeOccurred (String transition, 
String oldState, String newState) { 

if (newState. equals (ManagedServiceStateMachine.RUNNING_STATE) ) { 

running = true; 

runThread = new Thread (this) ; 

runThread . start ( ) ; 
} else if (runThread i= null) { 
running = false; 

try { 
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runThread . j oin { ) ; 
} catch (InterruptedException e) {} 
runThread = null; 

} 

} 

protected void resourceChangeOccurred( String resource, String oldValue, 
String newValue) {} 

protected synchronized void variableChangeOccurred( String variable, 
String oldValue, 

String newValue) { 

if (variable. equals {MESSAGE_VAR) ) 

{ 

message = newValue; 

} 

} 

protected boolean acceptStateChange (String transition. String oldState, 
String newState) { 
return true; 

) 

protected boolean acceptVariableChange (String variable, String oldValue, 
String newValue) { 
return true; 

} 

protected boolean acceptResourceChange (String resource, String oldValue, 
String newValue) { 
return true; 

} 

public static void main (String [] args) { 
try { 

new VerySimpleExampleB ( ) ; 
} catch (ESException e) { 
e .printStackTrace 0 ; 

} 

} 

} 

Here we have added a new Managed Variable that represents the time, which we 
update in the run method of our service. Viewing our service through the Service 
Manager now looks something lilte this: 
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Here we can see our new (read only) Time variable. Now when you start the service, 
each time you click the Update button, you see the most recent value of the time 
variable. 
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There are three classes of checked exceptions that can be thrown by the J-ESI APIs. 
They are: 

• ESInvocationException 

• ESServiceException 

• ESLibException 



ESInvocationException 

ESInvocationException is thrown usually when the engine (or the core) 
detects a problem wi± the request. Examples of such exceptions are quota 
exhausted or stale entry. 

• QuotaExhaustedException, as the name implies, is thro wn when there is no 
more space in the allocated quota of the client to hold any entries. 

• St aleEnt ryAccessExcept ion is thrown when the service which the request 
is destined for is stale and the request cannot be delivered to the service. 

For a detailed listing of all ESlnvocationExceptions, see "Exceptions'* in 
Chapter 8 of the e-speak Architectural Specifications, version 3,01. 
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ESServ i ceExcept i on 

ESServiceException happens when the core has delivered a request to the 
service, but the service has detected an error mth the request. Some of the service 
exceptions thrown by core services are, LookupFailedException thrown by 
the finder service when any lookup fails, Inval idNameExcept ion thrown by the 
folder service when any of the names passed is invalid. 

Any user specific exception defined also should extend ESServiceException. 
For example, if some one writes a printer service which can throw a 
Outof PaperException, this should extend ESServiceException. 

For a detailed listing of all these exceptions, see "Exceptions** in Chapter 8 of the e- 
speak Architectural Specifications, version 3.01. 



ESLibException 

ESLibException is usually thrown by the library itself when it has detected an 
error condition. For example, CoreNot FoundExcept ion is thrown when no core 
exists in the hostname : portnuiDber specified. 

Apart from these exceptions, ESRuntimeException is thrown to indicate a 
runtime failure. ESLibRuntimeException is a subclass of 
ESRuntimeException and is thrown in unexpected behavior conditions. 
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Description of Files on CD-ROM in CD-ROM Appendix 



Q 

W 
iij 
Q 

M: 

111 

\^ 
m 
o 
m 
a 
a 



test 

Volume in drive E is 001206_1632 
Volume Serial Number is 33CE-90D1 



Directory of E:\ 



12/06/00 04:32p <DIR> 
12/06/00 04:32p <DIR> 
12/06/00 04:33p <DIR> 
3 File(s) 

Directory of E : \e-speak:-src_991217 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
3 File(s) 



e-speak-src_991217 
0 bytes 



platform 
0 bytes 



Directory of E:\e-speak-src_991217\platform 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
3 File(s) 



ES 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES 



^12/06/00 
^12/06/00 
^12/06/00 
^12/06/00 
^12/15/99 
12/15/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/06/00 
12/07/99 
12/15/99 
12/15/99 
12/07/99 
12/05/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:00p 
04:00p 
04:25p 
04:33p 
04:25p 
04:25p 
04:33p 
04:33p 
04:25p 
04:00p 
04 : OOp 
04:25p 
04:33p 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



<DIR> 



<DIR> 
<DIR> 



<DIR> 
<DIR> 
<DIR> 



19 File(s) 



bin 

conf ig 
54,294 configure 
10,314 configure. in 
53 configure. nt 

contrib 
15,413 COPYING 
23,237 COPYING. LIB 

CVS 

extern 
20,163 HowTo.html 

4,224 include. mk. in 
13,149 Makefile. in 
1,509 make. rules 
samples 
src 

tutorial 
142,356 bytes 



Page 1 



xz, / uo / uu 


n /I . o Ov-v 
u<i : oop 


<DIR> 


±z/ uo/ uu 




<DIR> 


±^ / U Kj / uu 


Ufi . JOp 


<DIR> 


12/07 /9Q 


U *i . ^ op 




12/07/99 


04:25p 




12/07/99 


04:25p 




12/07/99 


04:25p 




12/07/99 


04:25p 




12/15/99 


04:00p 




12/07/99 


04:25p 






10 File(s) 





test 

Directory of E:\e-speak-src_991217\platform\ES\bin 



CVS 

2,04 0 envmake 
2,007 envmake.bat 
2, 673 envset 

27 eshome.bat 
7,292 genenv.pl 
17,909 install.pl 
35,269 run.pl 
67,217 bytes 

Directory of E:\e-speak-src_991217\platform\ES\bin\CVS 

12/06/00 04:33p <DIR> 

112/06/00 04:33p <DIR> 

m2/16/99 06:18p 321 Entries 

M12/16/99 05:17p 31 Repository 

W12/16/99 06:17p 46 Root 

W12/16/99 06:17p 846 Template 

6 File(s) 1,244 bytes 

iU Directory of E:\e-speak-src_991217\platform\ES\config 



CO 

22 col 
22 co2 
22 codef 
133 core.ini 
CVS 

1,039 default.ini 

14 9 espeak_ldap.prop 
management 
25 multiplecf .cfg 
510 repository.ini 
17 sample. cfg 
1,939 bytes 

Directory of E:\e-speak-src_991217\platform\ES\config\co 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:25p 22 col 

12/07/99 04:25p 22 colO 



i=^12/06/00 


04:33p 


<DIR> 


^142/06/00 


04:33p 


<DIR> 


^=312/06/00 


04:33p 


<DIR> 


^^fll2/07/99 


04:25p 




Ci2/07/99 


04:25p 




■^i2/07/99 


04:25p 




12/07/99 


04:25p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:25p 




12/07/99 


04:25p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:25p 




12/07/99 


04:25p 




12/07/99 


04:25p 






14 File(s) 
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test 





1 9 707 / QQ 


U 4 : z op 


22 


col . stress 




1 9 707 / QQ 


U4 : z op 


22 


co2 




/ u / / y y 


U4 : zop 


22 


co2 . stress 




iz/ u / / y y 


A / _ o rr 

04 : 2dp 


22 


co3 




1 9 /n7 / QQ 

/ u / / y y 


U4 : zop 


22 


co3 . stress 




1^:/ u / / y y 


U4 : 25p 


22 


co4 




iz/u //yy 


n /I - o c 

04 : 25p 


30 


co.SVEN.OMNIBOOKl 




iz / u / / y y 


04 : 25p 


22 


co4 . stress 




LZ/\J 1/33 


04 : 25p 


22 


co5 




iz/u / /yy 


n /I _ o cr 

0 4 : 2 5p 


30 


CO. SVEN. OMNI BOOK 




Ll/ \j1 / 33 


04 : 25p 


22 


co5 . stress 




1 9 / n7 / QQ 

iz / u / / y y 


U4 : z op 


22 


CO 6 




1 9 /n7 / QQ 

iz/ U 1/33 


U4 : zop 


24 


CO.PHIL.0MNI3 




1 o /n^ / d n 

iz/ U // y y 


04 : 2 op 


22 


co7 




1 9 / r\n / QQ 

iz / u / / y y 


U4 : zop 


22 


co8 




iz / U 1/33 


f\ A _ O IT — 

04 : zop 


22 


co9 




LZ/ \J 1/33 


04 : 2op 


24 


CO.PHIL.0MNI4 




LZ/ \J 1/33 


04 : 25p 


32 


co.CHIA.CHOWCHOWl 


''^^ 


iz/u //s?y 


04 : 25p 


24 


co.PHIL.IUl 




lz/07/9y 


04 : 25p 


24 


co.PHIL.IU24 




12/07/99 


04 : 25p 


33 


CO . SVEN . KAYAKl 




12/07/99 


04 :25p 


22 


co.CHIA. localhost 




1 o / r\i /an 

12/07/99 


04 : 25p 


22 


CO.MYC03 


m ■■ 


iz/u / / y 9 


r\ A or" 

04 : 25p 


24 


CO. PHIL.0MNI2 




iz/u //yy 


04 : 25p 


32 


CO.CHIA.CHOWCHOW 


i 


TO / r\i / r\ r\ 

iz/u //yy 


r\ A o r~ 

04 : 25p 


24 


CO. PHIL. IU23 




iz/u 1/33 


r\ A o c 

04 : 25p 


33 


CO . SVEN . KAYAK 




IZ/ \j 1/33 


n yi o !~ 

04 : 25p 


22 


CO.MYC02 


r." 


TO / nn / r\ r\ 

iz/u //y9 


n /I . o r 

04 : 25p 


24 


CO. PHIL. OMNI 




19 / nn / QQ 
iz/u 1/33 


04 : Zop 


24 


CO.PHIL.IU22 




TO / nn / c\ci 
LZ/ \J f / 33 


r\ A ■ O IT ™. 

04 : 2op 


22 


co.MYCOl 




12/07 /99 


\J rt • ^ U ^ 


"3 n 
JU 


CO . CHIA. OMNIBOOKl 




12/07/99 


04:25p 


24 


CO.PHIL.IU2 




12/07/99 


04:25p 


22 


co.MYCO 




12/07/99 


04:25p 


30 


co.CHIA.OMNIBOOK 




12/06/00 


04:33p <DIR> 




CVS 






40 File(s) 


906 


bytes 



Directory of E:\e-speak-src_991217\platforni\ES\config\co 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



1,736 Entries 
37 Repository 
4 6 Root 
84 6 Template 
2,665 bytes 
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test 

Directory of E:\e-speak-src_991217\platform\ES\config\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 420 Entries 

12/16/99 06:18p 32 Entries. Log 

12/16/99 06:18p 34 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,378 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\conf ig\management 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:25p 22 co2 dat 

12/06/00 04:33p <DIR> CVs' 

112/06/00 04:33p <DIR> html 

;0 12/07/99 04:25p 980 management.ini 

^'^f 6 File(s) 1,002 bytes 

W Directory of E:\e-speak-src_991217\platform\ES\config\management\CVS 



Entries 
Entries . Log 
Repository 
Root 

Template 
) bytes 

Directory of E: \e-speak-src_991217\platform\ES\conf ig\management\html 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> images 

12/07/99 04:25p 687 main.html 

12/07/99 04:25p 882 servlet . properties 

6 File{s) 1,569 bytes 

Directory of E:\e-speak-src_991217\platform\ES\config\management\html 

\cvs 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 104 Entries 



i=^12/06/00 


04:33p <DIR> 




iui2/06/00 


04:33p <DIR> 




12/16/99 


06:18p 


98 


i=*12/16/99 


06:18p 


14 


^^12/16/99 


06:18p 


45 


012/16/99 


06: 18p 


46 


W12/I6/99 


06: 18p 


846 




7 FileCs) 


1, 04 
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12/15/99 
12/16/99 
12/16/99 
12/16/99 



06:18p 
06:18p 
06:18p 
06:18p 
7 



File(s) 



test 

16 Entries. Log 
50 Repository 
4 6 Root 
84 6 Template 
1,062 bytes 



Directory of E: \e-speak-src_991217\platform\ES\conf ig\management\html 
\ images 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:25p 
04:33p 
04:25p 
04:25p 
04:25p 
04 :25p 
04:25p 
9 



<DIR> 
<DIR> 

<DIR> 



File (s) 



6,840 Closed.gif 
CVS 

6,910 Error.gif 
6,852 Initializing.gif 
5,058 logo.gif 
6,897 Ready.gif 
6,880 Running.gif 
39,437 bytes 



I Directory of E:\e-speak-src_991217\platform\ES\config\management\html 
^ \images\CVS 



=12/06/00 
^12/06/00 
12/16/99 
^12/16/99 
^12/16/99 
^12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06: 18p 
6 



<DIR> 
<DIR> 



File (s) 



288 Entries 
57 Repository 
46 Root 

84 6 Template 
1,237 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib 



12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/15/99 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:00p 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 

<DIR> 
<DIR> 



8 File(s) 



browser 
CVS 

gsysmon 
245 Makefile 
sysmon 
vf s 
245 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\browse] 



12/06/00 04:33p 
12/06/00 04:33p 
12/07/99 04:25p 



<DIR> 
<DIR> 



3,280 Browser. java 
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test 


12/06/00 


04 


: 33p 


<DIR> 


core 


12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/15/ 99 


04 


: OOp 




991 Makefile 


12/06/00 


04 


: 33p 


<DIR> 


tree 


12/06/00 


04 


: 33p 


<DIR> 


ui 


12/06/00 


04 


: 33p 


<DIR> 


util 






9 


File (s) 


4,271 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\browser\core 



12/06/00 04:33p 

12/06/00 04:33p 

12/07/99 04:40p 

12/06/00 04:33p 

12/07/99 04:40p 



5 File(s 



<DIR> 
<DIR> 

12,8 61 CoreBrowser . java 
<DIR> CVS 

390 Makefile 
13,251 bytes 



I Directory of E:\e-speak-src_991217\platform\ES\contrib\browser\core\C 
5VS 



^^12/06/00 
^12/06/00 
^12/16/99 
:l2/16/99 
^2/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06: IBp 
06:18p 
06: 18p 
6 



<DIR> 
<DIR> 



File (s) 



101 Entries 
48 Repository 
4 6 Root 

84 6 Template 
1,041 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\browser\CVS 



^-12/06/00 


04:33p 


<DIR> 




^-^12/06/00 


04:33p 


<DIR> 




12/16/99 


06:18p 




97 


12/16/99 


06: 18p 




54 


12/16/99 


06: 18p 




43 


12/16/99 


06: 18p 




46 


12/16/99 


06:18p 




846 



7 File(s) 1,086 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\contrib\browser\tree 



12/06/00 
12/05/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 



<DIR> 
<DIR> 



246 a.gif 

247 alert.red.gif 
242 alert.black.gif 

2,326 apache_pb.gif 
1,573 AttributePropertyNode. java 
Page 6 



LZ/\J I /39 


A 

04 


: 25p 


iz/U //99 


A /I 

04 


:25p 


12/07/99 


04 


: 25p 


lz/07/99 


A yi 

04 


: 25p 


12/07/99 


04 


: 25p 


lo / An / An 

12/07/99 


A /I 

04 


:25p 


TO / A^ / r\ r\ 

12/07/99 


04 


:25p 


10 / a*"? / r\ r\ 

12/07/99 


04 


:25p 


1 O / A^ / f\ r\ 

12/07/99 


04 


: 25p 


/ a*"? / aa 

12/07/99 


04 


:25p 


TO / AT / AA 

12/07/99 


A /I 

04 


: 25p 


TO /A^ / AA 

12/07/99 


04 


: 25p 


TO / A1 / AA 

12/07/99 


04 


: 25p 


TO / A""? / r\ r\ 

12/07/99 


04 


:25p 


TA / A*"? i r\ r\ 

12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


: 25p 


;,jl2/07/99 


04 


:25p 


12/07/99 


04 


:25p 


-.512/06/00 


04 


: 33p 


:^.^12/07/99 


04 


:25p 


^jfl2/07/99 


04 


:25p 




04 


: 25p 


;^12/07/99 


04 


: 25p 


:yl2/07/99 


04 


'25p 


;= 12/07/99 


04 ; 


25p 


:;7;12/07/99 


04 : 


25p 


:jfl2/07/99 


04 ; 


25p 


;;-;12/07/99 


04 : 


25p 


■->"t o i r\ ^ i f>. 

=ffl2/07/99 


04 : 


25p 


=^;fl2/07/99 


04 : 


25p 


^T A / A^ / f~\ r\ 

-^-12/07/99 


04 : 


25p 


12/07/99 


04 : 


25p 


TO /Of"* / ^ ^ 

12/07/99 


04 : 


25p 


12/07/99 


04 : 


25p 


TO / A^ / r\ r\ 

12/07/99 


04 : 


25p 


TO / A^ / r\ r\ 

12/07/99 


04 : 


25p 


12/07/99 


04 : 


25p 


TO /O'T / r\ r\ 

12/07/99 


04 : 


25p 


12/07/99 


04 : 


25p 


12/07/99 


04 : 


25p 


T o / AT / r\ r\ 

12/07/99 


04 : 


25p 


1 9/07 / QQ 




Zop 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/15/99 


04: 


OOp 


12/07/99 


04: 


25p 



test 

2,096 AttributeNode. java 
216 back.gif 
205 ball, red. gif 
233 ball.gray.gif 

2, 558 BaseNode . j ava 
246 binary.gif 

246 binhex.gif 
148 blank.gif 
308 bomb.gif 
251 boxl.gif 
268 box2.gif 

247 broken.gif 

235 burst.gif 

242 cgif 

1,038 compressed.gif 
24 6 comp.gray.gif 
251 comp.blue.gif 
214 continued.gif 
1,933 CoreManagedNode. java 
<DIR> CVS 

225 dir.gif 
163 down.gif 
238 dvi.gif 
1,621 ESContractNode oava 
1,619 ESNameFrameNode. java 
1,729 EsrlNode. java 
1,436 ESVocabularyNode. java 

236 f.gif 

225 folder.gif 

243 folder, sec. gif 

242 folder . open. gif 

219 forward. gif 
221 generic.gif 
249 generic.sec.gif 

220 generic. red. gif 
223 hand.up.gif 
217 hand.right.gif 

11, 977 icon. sheet .gif 
274 imagel.gif 
30 9 image2.gif 
28 5 image3.gif 
1, 467 InboxNode . j ava 
268 index.gif 
276 layout.gif 
172 left. gif 
249 link, gif 
969 Makefile 

243 movie.gif 
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test 



12/07/99 


04:25p 


237 


P . Cfif 


12/07/99 


04;25p 


251 


patch. gif 


12/07/99 


04:25p 


249 


pdf . gif 


12/07/99 


04:25p 


188 


pieO - gif 


12/07/99 


04:25p 


198 


piel . gif 


12/07/99 


04 :25p 


198 


Die2 . aif 


12/07/99 


04:25p 


191 


pie3 . gif 


12/07/99 


04 : 25p 


193 


Die4 crif 


12/07/99 


04 :25p 


189 


oie5 . aif 


12/07/99 


04:25p 


186 


pie 6 . gif 


12/07/99 


04 :25p 


185 


pie7 . gif 


12/07 /99 


04 : 25p 


173 


Die8 crif 


12/07/99 


04 :25p 


254 


portal . gif 


12/07/99 


04 ; 25p 


1, 458 


Protect ionDoitisinNode isvr^ 


12/07/99 


04 :25p 


244 


ps , gif 


12/07 /99 


04 : 25p 


267 


Cfu ill rr i f 


12/07 /99 


04 : 25p 


1, 438 


ResourcpDf^scrir^t ionNorie "i ava 

i. v^-w Iwl JL. \w< i-/ V-- J_ -L. k,/ W JU. w X V_il>>^ • 1 U V V— 4. 


312/07/99 


04 • 25d 


172 


T 1 crht" ni f 


'012/07/99 


04 : 25d 


1 400 


R.SDManNodp "lava 

Lyi. Id^LN • _j Ci V CI 


M12/07/99 


04 : 25p 


1, 768 


RsdNodp lava 

IviJ^^iNw^^ ■ _J CI V CI 


i-^Jl2/07/99 


04 * 25d 


258 


OV-'X.\J*in)X • -L J- 


^--^12/07/99 


04 : 25p 


263 




^□12/07/99 


04 : 25p 


242 


scriot crif 


="'12/07/99 


04 : 25p 


248 


qonnd 1 n i "P 


^'^ll2/07/99 


04 : 25p 


221 


<^ i » ^ JL J_ 


== 12/07/99 


04 : 25p 


285 


sdHptpI cti f 


1^4-2/07/99 


04 • 25d 


264 


crTvHpT^oO n"i "F 


^BL2/07/99 


04 :25p 


219 


tar . gif 


^^12/07/99 


04 • 25d 


251 


■h p V Cfif 

L. ^ iT^ • >^ JL J_ 


^^2/07/99 


04 : 25d 


229 


■h p vt" rr i f 


^3L2/07/99 


04 : 25p 


242 


transfer, crif 


^-12/07/99 


04 : 25p 


2^ 334 


TreeBrowser . i ava 


12/07 /99 


04 : 25p 


2, 435 


TreeCe 1 1 Rpnde T~p r iava 


12/07 /99 


04 • 25d 


3, 427 


T "TpeNodp Fa ct" o T~v "iava 


12/01 


04:25p 


8,315 


TreeResourceVisitor . java 


12/07/99 


04:25p 


245 


unknown, gif 


12/07/99 


04:25p 


164 


up. gif 


12/07/99 


04:25p 


236 


uu. gif 


12/07/99 


04:25p 


236 


uuencoded. gif 


12/07/99 


04:25p 


228 


worldl . gif 


12/07/99 


04:25p 


261 


world2 .gif 



96 File(s) 71,673 bytes 



Directory of E: \e-speak-src_991217\platf orin\ES\contrib\browser\tree\C 
VS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
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12/16/99 
12/16/99 
12/16/99 
12/16/99 



06:18p 
06:18p 
06:18p 
06:18p 
6 



test 
4,506 
48 
46 
846 



Entries 

Repository 

Root 

Template 



File (3) 5,446 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\contrib\browser\ui 



12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


: 25p 


12/07/99 


04 


:25p 


12/07/99 


04 


: 25p 


12/07/99 


04 


:25p 


012/06/00 


04 


: 33p 


^012/07/99 


04 


:25p 


=^12/07/99 


04 


:25p 


W12/07/99 


04 


:25p 


W12/07/99 


04 


:25p 


012/15/99 


04 


: OOp 


i^l2/07/99 


04 


:25p 


i1Jl2/07/99 


04 


:25p 


'■■^ 12/07/99 


04 


:25p 


^=^12/07/99 


04 


:25p 


^%2/07/99 


04 


:25p 


-^12/07/99 


04 


:25p 



<DIR> 
<DIR> 



<DIR> 



21 File(s) 



1,816 BrowserApp. java 
4,628 BrowserFrame. java 
1,780 BrowserView. java 
2,397 BrowserToolBar . java 
4,539 BrowserStatusBar. java 
1,555 BrowserMenuBar. java 
5,285 Connect Dig. java 
CVS 

2,699 FileMenu. java 
2,842 HelpMenu. java 

172 left.gif 
2,081 ListPane. java 

861 Makefile 
3,291 NumberField. java 

172 right. gif 
2,32 6 TreePane . java 
1,310 Utility. java 
3,722 ViewMenu . java 
1,388 ViewTypes . java 
42,864 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\browser\ui\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06: 18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



923 Entries 
46 Repository 
4 6 Root 

84 6 Template 
1,861 bytes 



Directory of E : \e-speak-src_991217\platf orra\ES\contrib\browser\util 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:25p 
04:33p 
04:25p 



<DIR> 
<DIR> 

<DIR> 



2,687 Application. java 
CVS 

8,388 DefaultResourceVisitor . java 
Page 9 



12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/15/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:25p 
04:25p 
04:25p 
04:25p 
04:00p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
16 



File{s; 



test 

5,278 ExternalResource. java 
2,667 FrameworkVocabulary. java 
1,517 FrameworkException. java 
3,131 FrameworkContext . java 
878 Makefile 
11,438 PrintResourceVisitor. java 
2,484 PrintTreeFactory. java 
2,981 ResourceVisitor . java 
5 , 682 ResourceProvider . j ava 
5,381 ResourceDiscover . java 
3,180 VocabularyFinder . java 
55,692 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\browser\util\C 
VS 



12/06/00 
^12/06/00 
il2/16/99 
U2/16/99 
112/16/99 
il2/16/99 



04:33p 
04:33p 
06: 18p 
06: 18p 
06: 18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



753 Entries 
48 Repository 
46 Root 
84 6 Template 
1,693 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\CVS 



n2/06/00 
J12/O6/OO 
312/16/99 
312/16/99 
^12/16/99 
312/16/99 
12/16/99 



04:33p 
04:33p 
06: 18p 
06:18p 
06: 18p 
06:18p 
06:18p 
7 



<DIR> 
<DIR> 



File (s) 



48 Entries 
63 Entries. Log 
35 Repository 
4 6 Root 
846 Template 
1,038 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\gsysmon 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/15/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:25p 
04:33p 
04:25p 
04:25p 
04 : OOp 
04:25p 
04:25p 



<DIR> 
<DIR> 

<DIR> 



9 File(s) 



5,116 BarSurf ace . java 
CVS 

1,806 Graphlntf . java 
7,034 GraphSurf ace. java 

533 Makefile 
8,4 39 SysMonGui . java 
7,198 TGFrame.java 
30, 126 bytes 
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test 

Directory of E: \e-speak-src_991217\platf orm\ES\contrib\gsysmon\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 305 Entries 

12/16/99 06:18p 43 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,240 bytes 



Directory of E:\e-speak-src_991217\platforin\ES\contrib\sysmon 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 386 Makefile 

12/07/99 04:25p 8,877 SysMon.java 

i3 5 File(s) 9,263 bytes 

'^1 Directory of E:\e-speak-src_991217\platform\ES\contrib\sysmon\CVS 

W12/O6/OO 04:33p <DIR> 

O12/O6/OO 04:33p <DIR> 

Ma2/16/99 06:18p 96 Entries 

^1=12/16/99 06:18p 42 Repository 

12/16/99 06:18p 46 Root 

H:12/16/99 06:18p 846 Template 

6 File(s) 1,030 bytes 

ifif Directory of E:\e-speak-src_991217\platform\ES\contrib\vfs 



42/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> config 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> src 

5 File(s) 0 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\vf s\conf ig 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/07799 


04 


:25p 




20 


col 


12/07/99 


04 


:25p 




20 


co2 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




2,895 


Makefile 


12/07/99 


04 


:25p 




1, 147 


Makefile.bat 


12/07/99 


04 


:25p 




135 


VFSBrowser . ini 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04 :25p 
04:25p 
04:25p 
04:25p 
04:25p 
13 



File (s) 



test 

272 VFSBrowser.prop 
147 VFSFileStore.ini 
448 VFSFileStore.prop 
137 VFSShell.ini 
272 VFSShell.prop 
5,493 bytes 



Directory of E : \e-speak-src_991217\platform\ES\contrib\vf s\conf ig\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s: 



486 Entries 
46 Repository 
4 6 Root 
84 6 Template 
1,424 bytes 



5 Directory of E:\e-speak-src_991217\platform\ES\contrib\vfs\CVS 



J12/O6/OO 
^^12/06/00 
yi2/16/99 
312/16/99 
*12/16/99 
^^12/16/99 
12/16/99 



04: 33p 
04:33p 
06:18p 
06: 18p 
06: 18p 
06:18p 
06:18p 
7 



<DIR> 
<DIR> 



File (s) 



3 Entries 
29 Entries. Log 
39 Repository 
4 6 Root 
84 6 Template 
963 bytes 



ff Directory of E:\e-speak-src_991217\platforra\ES\contrib\vfs\ 



src 



;i2/06/00 04:33p <DIR> 
=12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
4 File(s) 



CVS 
vf s 
0 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\vf s\src\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06:18p 
06:18p 
7 



<DIR> 
<DIR> 



File (s) 



3 Entries 
13 Entries. Log 
43 Repository 
4 6 Root 
84 6 Template 
951 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\vfs\src\vfs 
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test 



12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


1 0 / n c / r\r\ 
12/Ub/OU 


A A 

04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:25p 




12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 






10 File(s; 





Directory of E: \e-speak:-src_99 
owser 



browser 
clientapi 
CVS 
intf 
450 Makefile 
server 
shell 
util 
450 bytes 

17\platform\ES\contrib\vfs\src\vfs\br 



12/06/00 


04 


: 33p 


O12/O6/OO 


04 


: 33p 


^fil2/07/99 


04 


: 25p 


'^12/07/99 


04 


:25p 


W12/O7/99 


04 


: 25p 


W12/O7/99 


04 


:25p 


W12/07/99 


04 


:25p 


i=^12/07/99 


04 


: 25p 


^■^12/07/99 


04 


:25p 


:\12/07/99 


04 


:25p 


!f;12/07/99 


04 


:25p 


^3^12/06/00 


04 


:33p 


yi2/07/99 


04 


: 25p 


*12/07/99 


04 


:25p 


yi2/07/99 


04 


:25p 


^-12/07/99 


04 


: 25p 


12/07/99 


04 


25p 


12/06/00 


04: 


33p 


12/07/99 


04 : 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 


12/07/99 


04: 


25p 



<DIR> 
<DIR> 



<DIR> 



<DIR> 



4,924 AttributeViewListener . java 
31,720 AttributeView. java 
2,616 Attributeltem. java 
25, 061 Browser. java 

4 72 Browser . resources 
106,734 BrowsePane. java 

4,296 BrowsePane. resources 
7,855 BrowseDialog. java 
11, 116 CabinetAttributesDialog. java 
CVS 

2,476 DirectoryNode. java 

1, 614 DragData. java 

5,742 Filelnfo. java 

9,936 FileStoreListDialog. java 

7,950 FolderWatcher. java 
images 

7,139 InputDialog. java 
10,419 LaunchFile. java 

1, 120 Makefile 

5,151 MessageBoxOnTop. java 
15,865 NewFileDialog. java 
10,893 ProgressDialog. java 

6, 824 PropertiesDialog. java 
41,781 SearchPane. java 

5,214 SearchPane. resources 
11,054 SelectCabinetDialog. java 
10, 326 SelectCabinetDialog. resources 

3, 472 SplashScreen. java 
235,548 SplashScreen. resources 

1,805 SysImageList . java 
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test 

12/07/99 04:25p 7,510 TreeWatcher . j ava 

33 File(s) 597,633 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\br 
owser\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 
7 



<DIR> 
<DIR> 



File (s) 



1,610 Entries 

16 Entries. Log 
55 Repository 
4 6 Root 
846 Template 
2,573 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\br 
owser\images 



012/06/00 
J12/06/00 
4J12/O6/OO 
AJ12/O7/99 
□12/07/99 
=*12/07/99 
'112/07/99 
^ 12/07/99 
*L2/07/99 
%2/07/99 
»|l2/07/99 
512/07/99 
512/07/99 
i2/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

16 File{s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

9,484 FILECOPY.AVI 

1,238 HPLogo.bmp 

7 66 LCabClose. ICO 

7 66 LCabOpen.ICO 

766 LFile.ICO 

766 LFLDClose.ICO 

7 66 LFLDOpen.ICO 

318 SCabClose.ICO 

318 SCabOpen.ICO 

20,796 SEARCH.AVI 

318 SFile.ICO 

318 SFLDClose.ICO 

318 SFLDOpen.ICO 
36,938 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\br 
owser\images\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06: 18p 

6 File(s) 



<DIR> 
<DIR> 



634 Entries 
62 Repository 
4 6 Root 

84 6 Template 
1,588 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\cl 
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ientapi 



test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04 :25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
15 



<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 

707 Makefile 
2, 021 NoFileStoreFoundException. java 
5,825 VFSFileStoreContract. java 

26,093 VFSFileCabinet. java 
8, 312 VFSFileStoreVocabulary. java 

10,222 VFSFileStoreFinder. java 
1,969 VFSFileStoreElement . java 
4,040 VFSFileStoreDescription . j ava 

26,604 VFSFolder. java 

10, 343 VFSResourceVocabulary. java 
5,781 VFSResourceContract . java 

28,252 VFSWorkSpace. java 

130,169 bytes 



I Directory of E:\e-speak-src_991217\platform\ES\contrib\vfs\src\vfs\cl 
; ientapi \CVS 



^2/06/00 
= 12/06/00 
= 12/16/99 
12/16/99 
^12/16/99 
12/16/99 



04:33p 
04:33p 
06: 18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



712 Entries 
57 Repository 
4 6 Root 

84 6 Template 
1, 661 bytes 



rj Directory of E:\e-speak-src_991217\platform\ES\contrib\vfs\src\vfs\CV 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 48 Entries 

12/16/99 06:18p 95 Entries. Log 

12/16/99 06:18p 47 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File{s) 1,082 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\in 
tf 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 
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12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


. java 






12/07/99 


04 


:25p 



10 File(s) 



test 

556 Makefile 

5,670 VFSFilelntf . java 

1, 849 VFSFilelntfMessageRegistry. java 

10,400 VFSFileStub. java 

8,982 VFSFileStoreStub. java 

2, 223 VFSFileStorelntfMessageRegistry 

4,145 VFSFileStorelntf . java 
33,825 bytes 



Directory of E: \e-speak;-src_991217\platform\ES\contrib\vf s\src\vf s\in 
tf\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
312/16/99 
312/16/99 



04:33p 
04:33p 
G6:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



411 Entries 
52 Repository 
4 6 Root 
84 6 Template 
1,355 bytes 



y Directory of E: \e-speak:-src_991217\platform\ES\contrib\vf s\src\vf s\se 
iver 



lil2/06/00 
12/06/00 
=12/06/00 
142/07/99 
=42/15/99 
^12/07/99 
-12/07/99 
=12/07/99 
12/07/99 



04:33p 
04:33p 
04;33p 
04:25p 
04:00p 
04:25p 
04:25p 
04:25p 
04:25p 
9 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

9,327 DumpVFSEntries. java 
542 Makefile 

5,319 StartFileStore. java 
10,836 VFSFileStoreService. java 
25,820 VFSFileStorelmpl. java 
13,228 VFSFilelmpl. java 

65,072 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\se 
rver\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



332 Entries 
54 Repository 
4 6 Root 

84 6 Template 
1,278 bytes 



Directory of E:\e-speak -src 991217 \platf orra\ES \ contrib\vf s \ src\vf s \sh 
ell 
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test 



12/06/00 


04 : 33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04: 33p 


<DIR> 




12/07/99 


04 :25p 






12/07/99 


04:25p 




3, 


12/07/99 


04:25p 




3, 


12/07/99 


04 :25p 




20, 


12/07/99 


04 :25p 




10, 


12/07/99 


04:25p 




3, 


12/07/99 


04:25p 




7, 


12/07/99 


04:25p 




5, 


12/07/99 


04 :25p 




12, 


12/07/99 


04:25p 




8, 


12/07/99 


04:25p 




10, 


12/07/99 


04 :25p 




5, 


12/07/99 


04:25p 




6, 


012/07/99 


04:25p 




14, 


^fll2/07/99 


04:25p 




2, 


'^112/07/99 


04:25p 




4, 


W12/07/99 


04:25p 




10, 


Wl2/07/99 


04:25p 




6, 


O12/O7/99 


04:25p 




5, 


i""12/07/99 


04:25p 




5, 


^^12/07/99 


04:25p 




1, 


" 12/07/99 


04:25p 




15, 


^:^12/07/99 


04:25p 




7, 


^512/07/99 


04:25p 




1, 


yi2/07/99 


04 :25p 




3, 




28 


File (s) 


179 



Directory of E:\e-speak-src_991217 
ell\CVS 



CVS 

967 Makefile 
4 69 VFScatCoramand. java 
830 VFScdCommand. java 
17 9 VFSCommand. java 
028 VFScpCommand. java 
111 VFSechoCommand. java 
278 VFSexecCommand. java 
660 VFSexportCoininand. java 
226 VFSf indCommand. java 
167 VFS import Command, java 
912 VFSlsCommand. java 
754 VFSmkdirCommand. java 
212 VFSmkf ileCommand. java 
9 92 VFSmvCommand . j ava 
901 VFSpwdCommand . j a va 
57 6 VFSresetCommand. java 
724 VFSrmCommand. java 
855 VFSrmdirCommand. java 
909 VFSsetCommand. java 
98 6 VFSshareCommand. java 
776 VFSShellException. java 
496 VFSShell. java 
593 VFSshowCommand. java 
775 VFSStackException. java 
280 VFSStack. java 
r 656 bytes 

\platform\ES\contrib\vf s\src\vf s\sh 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 1,379 Entries 

12/16/99 06:18p 53 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 2,324 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\ut 
il 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 
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test 

12/07/99 04:25p 401 Makefile 

12/07/99 04:25p 3,469 VFSStrings . java 

5 File(s) 3,870 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\ut 
il\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 100 Entries 

12/16/99 06:18p 52 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,044 bytes 

Directory of E:\e-speak-src_991217\platform\ES\CVS 

^12/06/00 04:33p <DIR> 
U2/06/00 04:33p <DIR> 

n2/15/99 06:17p 431 Entries 

U2/16/99 06:22p 110 Entries. Log 

fl2/16/99 06:17p 27 Repository 

^2/16/99 06:17p 46 Root 

U2/16/99 06:17p 846 Template 

7 File(s) 1,460 bytes 

] Directory of E:\e-speak-src_991217\platform\ES\extern 

fl2/06/00 04:33p <DIR> 

f 12/06/00 04:33p <DIR> 

f 12/06/00 04:33p <DIR> CVS 

='12/06/00 04:33p <DIR> Idap 

12/06/00 04:33p <DIR> openxral 

12/06/00 04:33p <DIR> oracle-lib 

6 File (s) 0 bytes 

Directory of E:\e-speak-src_991217\platform\ES\extern\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 3 Entries 

12/16/99 06:18p 51 Entries. Log 

12/16/99 06:18p 34 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 980 bytes 



Directory of E:\e-speak-src_991217\platform\ES\extern\ldap 
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test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 

12/08/99 01:52p 160,475 Idapjdk. j ar 

4 File{s) 160,475 bytes 

Directory of E:\e-speak-src_991217\platforin\ES\extern\ldap\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 51 Entries 

12/16/99 06:18p 39 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 982 bytes 

□ Directory of E:\e-speak-src_991217\platform\ES\extern\openxml 

;^il2/06/00 04:33p <DIR> 

W12/O6/OO 04:33p <DIR> 

^12/06/00 04:33p <DIR> CVS 

:=:l2/08/99 01:49p 357,071 openxml.jar 

;^ 4 File{s) 357, 071 bytes 

Directory of E:\e-speak-src_991217\platform\ES\extern\openxml\CVS 

Q^12/06/00 04:33p <DIR> 

yi2/06/00 04:33p <DIR> 

:ifl2/16/99 06:18p 51 Entries 

:^12/16/99 06:18p 42 Repository 

^=12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File{s) 985 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\extern\oracle-lib 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/08/99 01:57p 800,174 classeslll.zip 

12/06/00 04:33p <DIR> CVS 

4 File(s) 800,174 bytes 

Directory of E: \e-speak-src_991217\platform\ES\extern\oracle-lib\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 54 Entries 
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12/16/99 
12/16/99 
12/16/99 



06: 18p 
06:18p 
06:18p 

6 File(s) 



test 

45 Repository 
4 6 Root 
84 6 Template 
991 bytes 



Directory of E: \e-speak:-src_991217\platf orm\ES\samples 



12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


:33p 


<DIR> 


echo 


12/06/00 


04 


: 33p 


<DIR> 


ESChat 


12/07/99 


04 


:25p 




290 Makefile 


12/06/00 


04 


: 33p 


<DIR> 


ManagedEcho 


12/06/00 


04 


: 33p 


<DIR> 


ManagedPrintServer 


12/06/00 


04 


:33p 


<DIR> 


PrintServer 






9 


File(s) 


290 bytes 



3 Directory of E:\e-speak-src_991217\platform\ES\samples\CVS 



4iL2/06/00 
442/06/00 
312/16/99 
=12/16/99 
%2/16/99 
12/16/99 
=12/16/99 



04:33p 
04:33p 
06:18p 
06:19p 
06:18p 
06:18p 
06:18p 
7 



<DIR> 
<DIR> 



File (s) 



48 Entries 
100 Entries. Log 

35 Repository 

4 6 Root 
84 6 Template 
1,075 bytes 



ff Directory of E:\e-speak-src_991217\platform\ES\samples\echo 



42/06/00 
12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:25p 
04:25p 
04:33p 
7 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



<DIR> 



File (s) 



conf ig 
CVS 

4,998 echo.vjp 
4,127 README.txt 
src 
9,125 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\conf 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:25p 
04:25p 
04:33p 
04:33p 



<DIR> 
<DIR> 



<DIR> 
<DIR> 



25 col.MYCO 

26 CO2.MYC0 
CVS 

multicore 
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12/06/00 04:33p <DIR> 
7 File(s) 



test 



singlecore 
51 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\conf ig\CV 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06: 19p 
06: 19p 
7 



<DIR> 
<DIR> 



File (s) 



93 Entries 
39 Entries. Log 
47 Repository 
46 Root 
846 Template 
1,071 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\saraples\echo\conf ig\mu 
Iticore 



312/06/00 
112/06/00 
J12/07/99 
il2/06/00 
^12/07/99 
^12/07/99 
='12/07/99 



04:33p 
04:33p 
04 :25p 
04:33p 
04:25p 
04:25p 
04:25p 
7 



<DIR> 
<DIR> 

<DIR> 



File(s) 



64 client. prop 
CVS 

744 EchoClient.ini 
730 EchoServer.ini 
42 server. prop 
1,580 bytes 



J Directory of E:\e-speak-src_991217\platform\ES\samples\echo\config\inu 
flticoreXCVS 



fl2/06/00 
^12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04: 33p 
04:33p 
06:19p 
06:19p 
06:19p 
06: 19p 
6 



<DIR> 
<DIR> 



File{s) 



201 Entries 
57 Repository 
46 Root 

84 6 Template 
1, 150 bytes 



nglecore 








12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


:25p 




12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


: 25p 




12/07/99 


04 


:25p 




12/07/99 


04 


:25p 





60 client. prop 
CVS 

199 EchoClient.ini 
328 EchoServer.ini 
60 server. prop 
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7 File(s) 



test 

647 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples\echo\config\si 
nglecoreXCVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 201 Entries 

12/16/99 06:19p 58 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,151 bytes 

Directory of E:\e-speak-src_991217\platform\ES\saiiiples\echo\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

S12/16/99 06:19p 95 Entries 

112/16/99 06:19p 29 Entries. Log 

112/16/99 06:19p 40 Repository 

112/16/99 06:19p 46 Root 

a2/16/99 06:19p 846 Template 

[ 7 File{s) 1,056 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\echo\src 



CVS 

EchoServer . j ava 
EchoClient. java 
EchoServicelntf . esidl 
EchoServiceStub . j ava 
EchoServicelntfMessageRegistry . 

EchoServicelntf. java 



Makefile 
12 File(s) 46,221 bytes 

Directory of E : \e-speak-src_991217\platf oriii\ES\samples\echo\src\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 501 Entries 

12/16/99 06:19p 44 Repository 

12/16/99 06:19p 46 Root 
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^'*12/06/00 


04:33p 


<DIR> 




^12/06/00 


04:33p 


<DIR> 




yi2/06/00 


04:33p 


<DIR> 




^2/07/99 


04:25p 




5,216 


yi2/07/99 


04:25p 




6,205 


^3l2/07/99 


04:25p 




2, 397 


12/07/99 


04:25p 




3,838 


12/07/99 


04:25p 




1, 388 


java 








12/07/99 


04:25p 




2,397 


12/07/99 


04:25p 




2,103 


12/07/99 


04:25p 




22,016 


12/07/99 


04:25p 




661 



test 

12/16/99 06:19p 846 Template 

6 File(s) 1,437 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples\ESChat 

<DIR> 
<DIR> 

<DIR> config 
<DIR> CVS 

3,550 README -txt 
<DIR> src 

Lie (s) 3, 550 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\ESChat\conf ig 

<DIR> 
<DIR> 

<DIR> CVS 

<DIR> multicore 

<DIR> singlecore 

5 File (s) 0 bytes 



12/06/00 


04: 


33p 


12/06/00 


04: 


33p 


12/06/00 


04: 


33p 


12/06/00 


04: 


33p 


12/07/99 


04: 


25p 


12/06/00 


04 : 


33p 
6 


Directory of 


■ E: 


12/06/00 


04: 


33p 


12/06/00 


04: 


33p 


□12/06/00 


04: 


33d 


812/06/00 


04: 


33p 


'^Jl2/06/00 


04: 


33p 
5 


O Directory of 


' E: 








12/06/00 


04: 


33p 


^=^12/06/00 


04: 


33p 


%2/16/99 


06: 


18p 


^3l2/16/99 


06: 


18p 


W12/I6/99 


06: 


18p 


^312/16/99 


06: 


18p 


^=<L2/16/99 


06: 


18p 



<DIR> 
<DIR> 

3 Entries 

39 Entries. Log 

4 9 Repository 

4 6 Root 

846 Template 
7 File(s) 983 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\ESChat\conf ig\ 
multicore 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/07/99 


04 


:25p 




58 


client .pr 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




757 


ESChat Server . ini 


12/07/99 


04 


:25p 




164 


ESChatClient.ini 


12/07/99 


04 


: 25p 




570 


ESChatAddCore . ini 


12/07/99 


04 


:25p 




58 


server .pr 



8 File(s) 1,607 bytes 



Directory of E: \e-speak-src__991217\platf orm\ES\samples\ESChat\conf ig\ 
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multicoreXCVS 



test 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



255 Entries 
59 Repository 
4 6 Root 

84 6 Template 
1,206 bytes 



Directory of E: \e-speak;-src_991217\platforin\ES\samples\ESChat\conf ig\ 
singlecore 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
:il2/07/99 
J12/07/99 
=112/07/99 



04:33p 
04:33p 
04:25p 
04:33p 
04:25p 
04:25p 
04:25p 
7 



<DIR> 
<DIR> 

<DIR> 



File (s) 



57 client. pr 

CVS 

740 ESChatServer.ini 
204 ESChatClient.ini 
57 server. pr 
1,058 bytes 



i Directory of E:\e-speak-src_991217\platform\ES\samples\ESChat\config\ 
'singlecore\CVS 



^ 12/06/00 
='*12/06/00 
142/16/99 
»lL2/16/99 
142/16/99 
3L2/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



201 Entries 
60 Repository 
4 6 Root 
84 6 Template 
1,153 bytes 



Directory of E: \e-speak-src_991217\platform\ES\samples\ESChat\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06: 18p 
06:18p 
06:18p 
06:18p 
06:18p 
7 



<DIR> 
<DIR> 



File (s) 



50 Entries 
29 Entries. Log 
42 Repository 
4 6 Root 
84 6 Template 
1,013 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ESChat\src 



12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
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test 

12/07/99 04:25p 3,466 ChatEventDist . i ava 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 23,040 ESChatUML.doc 

12/07/99 04:25p 9,527 ESChat.java 

12/07/99 04:25p 404 Makefile ■ 

12/07/99 04:25p 3,219 MessageDialog . j ava 

12/07/99 04:25p 3,185 Subscriberlmpl . java 

9 File(s) 42,841 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\ESChat\src\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 312 Entries 

12/16/99 06:18p 46 Repository 

12/16/99 06:18p 46 Root 

^12/16/99 06:18p 846 Template 

;^ 6 File(s) 1,250 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedEcho 

W12/O6/OO 04:33p <DIR> 
012/06/00 04:33p <DIR> 

ifl2/06/00 04:33p <DIR> config 

^"12/06/00 04:33p <DIR> CVS 

f. 12/07/99 04:25p 2,236 README.txt 

;r:i2/06/00 04:33p <DIR> src 

6 File (s) 2, 236 bytes 

;if Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedEcho\co 

;g:ifig 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 25 col.MYCO 

12/07/99 04:25p 26 co2.MYC0 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 443 ManagedEcho.ini 

12/07/99 04:25p 108 testMgr.ini 

7 File(s) 602 bytes 

Directory of E: \e-speak-src_991217\platform\ES\sainples\ManagedEcho\co 
nfig\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 193 Entries 

12/16/99 06:18p 54 Repository 
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12/16/99 06:18p 
12/16/99 06:18p 

6 File(s) 



test 

4 6 Root 
846 Template 
1,139 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedEcho\CV 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 

7 File(s) 



<DIR> 
<DIR> 



50 Entries 
29 Entries. Log 
47 Repository 
4 6 Root 
846 Template 
1,018 bytes 



Directory of E: \e-speak:-src_991217\platf orm\ES\samples\ManagedEcho\sr 



i=:PC 



^112/06/00 


04: 


33p 




<DIR> 


W12/06/00 


04: 


33p 




<DIR> 


UJ12/06/00 


04: 


33p 




<DIR> 


^2/07/99 


04: 


25p 






K2/07/99 


04: 


25p 






mi2/07/99 


04: 


25p 






'■' java 










^"^2/07/99 


04: 


2 5p 






^Vl2/07/99 


04: 


25p 






^112/07/99 


04: 


25p 






^3i2/07/99 


04: 


25p 






^3L2/07/99 


04: 


25p 






^=12/07/99 


04: 


25p 










12 


File (s) 




Directory of 


E:\e-speak 


;-src 


c\CVS 










12/06/00 


04: 


33p 




<DIR> 


12/06/00 


04: 


33p 




<DIR> 


12/16/99 


06: 


18p 






12/16/99 


06: 


18p 






12/16/99 


06: 


18p 






12/16/99 


06: 


18p 










6 


File (s) 





CVS 

2,212 EchoServicelntf . esidl 

2,34 3 EchoServiceStub . java 

1,408 EchoServicelntfMessageRegistry . 

2,216 EchoServicelntf . java 
2, 154 EchoServicelmpl . java 

688 Makefile 
6, 077 ManagedEcho , j ava 
2, 632 startManagedEcho . java 
4,196 testMgr.java 
23, 926 bytes 



509 Entries 
51 Repository 
4 6 Root 
84 6 Template 
1, 452 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver 
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test 



xz/ uo/ UU 


u4 : o Jp 


<DIR> 


• 


IZ/ UD/ UU 


U4 : J jp 


<DIR> 




XZ/ UD/ UU 


U4 : J Jp 


<DIR> 


conf ig 


12/06/00 


04:33p 


<DIR> 


CVS 


12/05/00 


04:33p 


<DIR> 


doc 


12/09/99 


06:44a 




5,800 README.txt 


12/06/00 


04:33p 


<DIR> 


SampleFiles 


12/06/00 


04:33p 


<DIR> 


src 



8 File(s) 5,800 bytes 



Directory of E: \e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
rverXconf ig 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


multicore 


□12/07/99 


04 


:25p 




380 Print.ini 


fll2/06/00 


04 


: 33p 


<DIR> 


singlecore 






6 


File (s) 


380 bytes 



% Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedPrintSe 

;==rver\conf ig\CVS 

^^12/06/00 04:33p <DIR> 

1^ 12/06/00 04:33p <DIR> 

r;12/16/99 06:18p 49 Entries 

1^2/16/99 06:18p 39 Entries. Log 

'^2/16/99 06:18p 61 Repository 

3.2/16/99 06:18p 46 Root 

-12/16/99 06:18p 846 Template 

7 File(s) 1,041 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rverXconf ig\multicore 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 42 Client. prop 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 341 PC.ini 

12/07/99 04:25p 538 PC-Core. ini 

12/09/99 07:02a 1,696 PS. ini 

7 File(s) 2,617 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
rverXconf ig\multicore\CVS 
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test 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 185 Entries 

12/16/99 06:18p 71 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,148 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\conf ig\singlecore 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 42 Client. prop 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 220 PC. ini 

12/07/99 04:25p 376 print.ini 

112/09/99 07:03a 1,278 PS. ini 

112/07/99 04:25p 42 Server. prop 

1 8 File(s) 1,958 bytes 

I Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
lrver\conf ig\singlecore\CVS 

J12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

^•12/16/99 06:18p 231 Entries 

112/16/99 06:18p 72 Repository 

:il2/16/99 06:18p 46 Root 

J12/16/99 06:18p 846 Template 

1 6 File(s) 1,195 bytes 

Directory of E: \e-speak:-src_991217\platf orm\ES\samples\iy[anagedPrintSe 



rver\CVS 








12/06/00 


04: 


33p <DIR> 




12/06/00 


04: 


33p <DIR> 




12/16/99 


06: 


18p 


50 Entries 


12/16/99 


06: 


18p 


63 Entries. Log 


12/16/99 


06: 


18p 


54 Repository 


12/16/99 


06: 


18p 


4 6 Root 


12/16/99 


06: 


18p 


84 6 Template 






7 File(s) 


1,059 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\doc 



12/06/00 04:33p <DIR> 
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12/06/00 
12/06/00 
12/09/99 



04:33p 
04:33p 
07:01a 

4 File(s: 



<DIR> 
<DIR> 



test 

CVS 

96,647 Userguide.doc 
96,647 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\doc\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06: 18p 
6 



<DIR> 
<DIR> 



File(s) 



53 Entries 
58 Repository 
4 6 Root 
84 6 Template 
1,003 bytes 



Directory of E:\e-speak-src_991217\platform\ES\saraples\ManagedPrintSe 
lrver\Sample Files 



^112/06/00 
:Jl2/06/00 
il2/06/00 
312/07/99 
^12/07/99 
J12/07/99 
12/07/99 
^12/07/99 



04:33p 
04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 



<DIR> 
<DIR> 
<DIR> 



8 File(s: 



CVS 

181,760 test. doc 
351 test.ini 
6 test.ppt 
49 test.txt 
6 test.xls 
182,172 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
yver\SampleFiles\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06: 18p 
06: 18p 
06: 18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s; 



228 Entries 
66 Repository 
4 6 Root 

84 6 Template 
1, 186 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedPrintSe 



rver\src 



12/06/00 
12/06/00 
12/06/00 
12/15/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:00p 
04:25p 



<DIR> 
<DIR> 
<DIR> 



CVS 

799 Makefile 
10,298 ManagedPrint Service. java 
Page 29 



IZ / (J 1/33 


04 


: 25p 




U 4 


• 9 

• z op 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 



12 File(s) 



test 

6,133 PolicyWriter . java 
18,611 PrintClient. java 

3,805 PrinterStub. java 

1,884 Printerlntf . java 
14,133 Printerlmpl . java 

5,539 Print Joblnfo. java 
18,441 PrintServer . java 

79,643 bytes 



Directory of E: \e-speak-src_991217\platforin\ES\samples\ManagedPrintSe 
rver\src\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
112/16/99 



04:33p 
04:33p 
06: 18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



482 Entries 
58 Repository 
46 Root 
84 6 Template 
1,432 bytes 



File (s) 

Directory of E: \e-speak-src_991217\platform\ES\samples\PrintServer 



conf ig 
CVS 

4,4 99 README.txt 
SampleFiles 
src 
4,499 bytes 



O12/06/00 


04 


:33p 


<DIR> 


i'^12/06/00 


04 


: 33p 


<DIR> 


11112/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


^=^12/07/99 


04 


: 25p 




^m2/06/00 


04 


:33p 


<DIR> 


^312/06/00 


04 


: 33p 


<DIR> 






7 


File (s) 



nf ig 








12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


: 25p 




12/07/99 


04 


: 25p 




12/07/99 


04 


:25p 




12/07/99 


04 


: 25p 




12/07/99 


04 


: 25p 




12/06/00 


04 


: 33p 


<DIR> 



12 File(s) 



col 
co2 
CVS 

multicore 
2 97 Print.ini 
1,973 printer .xml 
1, 688 printerl.xml 
1,760 printit.pl 
1,571 printVocab.xml 
singlecore 
7,28 9 bytes 
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test 

Directory of E: \e-speak-src_991217\platform\ES\samples\PrintServer\co 
nf igXcol 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 25 col.MYCO 

12/06/00 04:33p <DIR> CVS 

4 File(s) 25 bytes 

Directory of E: \e-speak-src_991217\platform\ES\saraples\PrintServer\co 
nfig\col\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 48 Entries 

12/16/99 06:18p 58 Repository 

12/16/99 06:18p 46 Root 

312/16/99 06:18p 846 Template 

6 File(s) 998 bytes 

W Directory of E:\e-speak-src_991217\platform\ES\saraples\PrintServer\co 
;ffnfig\co2 

^:^12/06/00 04:33p <DIR> 

^^12/06/00 04:33p <DIR> 

f, 12/07/99 04:25p 25 ci2.MYC0 

:=:12/06/00 04:33p <DIR> CVS 

'H; 4 File(s) 25 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\PrintServer\co 
gnfig\co2\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 48 Entries 

12/16/99 06:18p 58 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 998 bytes 

Directory of E: \e-speak-src_991217\platform\ES\samples\PrintServer\co 
nfigXCVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 244 Entries 

12/16/99 06:18p 65 Entries. Log 

12/16/99 06:18p 54 Repository 
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12/16/99 
12/16/99 



06:18p 
06:18p 

7 File(s) 



test 

4 6 Root 
846 Template 
1,255 bytes 



nf ig\multicore 




12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:25p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:25p 




12/07/99 


04:25p 




12/07/99 


04:25p 






7 


File (s) 



42 Client. prop 
CVS 
202 PC.ini 
557 PC-Core. ini 
817 PS. ini 
1,618 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\PrintServer\co 
inf ig\multicore\CVS 



J12/06/00 
J12/06/00 
J12/16/99 
312/16/99 
^^12/16/99 
42/16/99 



04:33p 
04:33p 
06:18p 
06: 18p 
05: 18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



185 Entries 
64 Repository 
4 6 Root 
84 6 Template 
1,141 bytes 



y Directory of E:\e-speak-src_991217\platforin\ES\samples\PrintServer\co 
•jnf ig\singlecore 



=12/06/00 
=12/06/00 
12/07/99 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04 :25p 
04:33p 
04 :25p 
04 :25p 
6 



<DIR> 
<DIR> 

<DIR> 



File (s) 



42 Client. prop 
CVS 
184 PC.ini 
426 PS. ini 

652 bytes 



Directory of E:\e-speak-src_991217\platform\ES\sainples\PrintServer\ 
nf ig\singlecore\CVS 



CO 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



137 Entries 
65 Repository 
4 6 Root 

84 6 Template 
1,094 bytes 
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test 



Directory of E: \e-speak-src__991217\platf oriti\ES\samples\PrintServer\CV 

S 



12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:18p 


50 Entries 


12/16/99 


06:18p 


50 Entries. Log 


12/16/99 


06:18p 


47 Repository 


12/16/99 


06:18p 


46 Root 


12/16/99 


06:18p 


84 6 Template 




7 File(s) 


1,039 bytes 



Directory of E: \e-speak-src__991217\platf orm\ES\sainples\PrintServer\Sa 
mpleFiles 



12/06/00 


04 


: 33p 


1:112/06/00 


04 


: 33p 


:Ol2/06/00 


04 


:33p 


'yi2/07/99 


04 


:25p 


UJ12/07/99 


04 


:25p 


UI12/07/99 


04 


: 25p 


1312/07/99 


04 


:25p 


m2/07/99 


04 


:25p 



<DIR> 
<DIR> 

<DIR> CVS 

181,760 test. doc 
351 test.ini 
6 test.ppt 
49 test.txt 
6 test.xls 

iU 8 File{s) 182,172 bytes 

i'^ Directory of E: \e-speak:-src_991217\platform\ES\samples\PrintServer\Sa 
lUnpleFilesXCVS 

^2/06/00 04:33p <DIR> 
O12/06/00 04:33p <DIR> 

a2/16/99 06:18p 228 Entries 

12/16/99 06:18p 59 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,179 bytes 



Directory of E: \e-speak-src_991217\platform\ES\samples\PrintServer\sr 

c 



12/06/00 04:33p 

12/06/00 04:33p 

12/06/00 04:33p 

12/15/99 04:00p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 



<DIR> 
<DIR> 
<DIR> 

995 
6,152 
16,750 
2,375 
2, 524 
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CVS 

Makefile 

PrintServer . j ava 
PrintClient . j ava 
Print Joblnfo . esidl 
Print Joblnfo . j ava 



12/07/99 

12/07/99 

12/07/99 

12/07/99 

. java 

12/07/99 

12/07/99 



04:25p 
04 :25p 
04:25p 
04 :25p 

04:25p 
04:25p 

14 File(s) 



test 

60,928 PrintServerUML.doc 
2,343 PrintServicelntf , esidl 
2,958 PrintServiceStub. java 
1, 574 PrintServicelntfMessageRegistry 

2,347 PrintServicelntf . java 
5,187 PrintServicelmpl . java 
105,133 bytes 



Directory of E: \e-speak-src_991217\platform\ES\samples\PrintServer\sr 
c\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
il2/16/99 



04:33p 
04:33p 
06: 19p 
06: IBp 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



624 Entries 
51 Repository 
4 6 Root 

846 Template 
1,567 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src 



^12/06/00 
=12/06/00 
112/06/00 
12/06/00 
^12/06/00 
^12/06/00 
^12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
7 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 



File (s) 



c 

CVS 
j ava 
perl 
python 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\c 



12/06/00 
12/06/00 
12/06/00 
12/06/00 



04: 33p 
04:33p 
04:33p 
04:33p 
4 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



File (s) 



cesi 
CVS 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\c\cesi 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 



04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:33p 



<DIR> 
<DIR> 



<DIR> 



49,436 abi.c 
16,525 abi.h 
15,614 abi_base.c 
4,223 abi_base.h 
CVS 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

17 File(s) 



test 
19,827 
3,512 
620 
631 
408 
3,716 
8,036 
3,745 
5, 654 
13,071 
145, 018 



eslib. c 
eslib.h 
makefile 
makef ile_w32 
README . txt 
rtc. c 
rts . c 
tc. c 
ts . c 

wservpipe . c 
bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\c\cesi\CVS 



12/06/00 
12/06/00 
12/16/99 
112/16/99 
312/16/99 
J12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06: 19p 
06:19p 

6 File(s] 



<DIR> 
<DIR> 



624 Entries 
38 Repository 
4 6 Root 
84 6 Template 
1,554 bytes 



3 Directory of E:\e-speak-src_991217\platform\ES\src\c\CVS 



m2/06/00 
12/06/00 
===-12/16/99 
m2/16/99 
:i2/16/99 
112/16/99 
12/16/99 



04:33p 
04:33p 
06: 19p 
06:19p 
06:19p 
06:19p 
06:19p 

7 File(s; 



<DIR> 
<DIR> 



3 Entries 
14 Entries. Log 
33 Repository 
4 6 Root 
846 Template 
942 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:22p 
06:19p 
06:19p 
06:19p 
7 



<DIR> 
<DIR> 



File (s) 



3 Entries 
55 Entries. Log 
31 Repository 
46 Root 
84 6 Template 
981 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java 



12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
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test 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 187 Makefile 

12/06/00 04:33p <DIR> net 

5 File(s) 187 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 48 Entries 

12/15/99 06:19p 13 Entries. Log 

12/16/99 06:19p 36 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File{s) 989 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> espeak 

4 File(s) 0 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\CVS 



12/06/00 


04: 


33p 


<DIR> 




12/06/00 


04: 


33p 


<DIR> 




12/16/99 


06: 


19p 




3 Entries 


12/16/99 


06: 


19p 




16 Entries. Log 


12/16/99 


06: 


19p 




40 Repository 


12/16/99 


06: 


19p 




4 6 Root 


12/16/99 


06: 


19p 




846 Template 






7 


File(s) 


951 bytes 


Directory of 


E:\e-speak-src_I 


991217 \platform\ES\src' 


12/06/00 


04: 


33p 


<DIR> 




12/06/00 


04: 


33p 


<DIR> 




12/06/00 


04: 


33p 


<DIR> 


CVS 


12/06/00 


04: 


33p 


<DIR> 


infra 


12/06/00 


04: 


33p 


<DIR> 


jesi 


12/07/99 


04: 


25p 




477 Makefile 


12/06/00 


04: 


33p 


<DIR> 


services 


12/06/00 


04: 


33p 


<DIR> 


util 


12/07/99 


04: 


25p 




2,099 Version. java 


12/06/00 


04: 


33p 


<DIR> 


webaccess 






10 


File (s) 


2,57 6 bytes 
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test 



Directory of E: \e-speak-src_991217\platf orin\ES\src\ java\net\espeak\CV 

S 



12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:19p 


97 Entries 


12/16/99 


06:21p 


80 Entries. Log 


12/16/99 


06:19p 


47 Repository 


12/16/99 


06:19p 


46 Root 


12/16/99 


06:19p 


846 Template 




7 File(s) 


1,116 bytes 



Directory of E:\e-speak-src 991217\platf orm\ES\ src\ j ava\net \espeak\in 
fra 



12/06/00 


04:33p 


<DIR> 




=1 12/06/00 


04:33p 


<DIR> 




fl 12/06/00 


04:33p 


<DIR> 


cci 


3 12/06/00 


04:33p 


<DIR> 


client 


jj 12/06/00 


04:33p 


<DIR> 


core 


iij 12/06/00 


04 :33p 


<DIR> 


CVS 


a 12/06/00 


04:33p 


<DIR> 


intercorecom 


Ui= 12/07/99 


04:25p 




269 Makefile 


llJ 12/06/00 


04:33p 


<DIR> 


xml 




9 


File (s) 


269 bytes 



nJ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci 



1312/06/00 


04 


:33p 


<DIR> 




012/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 


coreapi 


12/06/00 


04 


: 33p 


<DIR> 


coreproxy 


12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


.•33p 


<DIR> 


events 


12/06/00 


04 


:33p 


<DIR> 


exception 


12/06/00 


04 


:33p 


<DIR> 


export 


12/07/99 


04 


:25p 




357 Makefile 


12/06/00 


04 


:33p 


<DIR> 


management 


12/06/00 


04 


:33p 


<DIR> 


messaging 


12/06/00 


04 


:33p 


<DIR> 


metadata 


12/06/00 


04 


:33p 


<DIR> 


naming 


12/06/00 


04 


: 33p 


<DIR> 


security 






14 


File (s) 


357 bytes 



Directory of E: \e-speak-src_991217\platf orin\ES\src\ java\net\espeak\in 
fra\cci\coreapi 
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test 



1^/Ub/UU 


C\ A 


- '3 

: oop 


14.1 Ub/ UU 




: J Jp 


iz/v / / y y 


C\ A 


: Zap 


12/0 //yy 


04 


: zop 


Iz/ 05/ UU 


04 


: J Jp 


1Z/\J 1/33 


04 


. O C -.^ 

: zop 


1 0 / m / OQ 
iz / u / / y y 


U 4 


. z op 


12/07/99 


04 


: 25p 


12/07/99 


04 


: 25p 


12/07/99 


04 


: 25p 


12/07/99 


04 


: 25p 


12/07/99 


04 


: 25p 


12/07/99 


04 


: zop 


12/07/99 


04 


:25p 


ava 






12/07/99 


04 


:25p 


T 12/07/99 


04 


:25p 


S 12/07/99 


04 


:25p 


y 12/07/99 


04 


:25p 


12/07/99 


04 


:25p 



<DIR> 
<DIR> 



<DIR> 



19 File(s) 



6,485 CoreManagementlnterf ace . java 
8,572 CoreNames . java 
CVS 

8, 625 ImporterExporterlnterf ace . java 
2,698 Keylnterf ace. java 
4,645 KeyRinglnterf ace . java 
5,388 Mailboxinterf ace . java 

805 Makefile 
9,933 NameFr ameint erf ace . java 
5, 301 ProtectionDomainlnterf ace • java 
6, 118 RepositoryViewInterf ace .java 
24, 869 ResourceManipulationlnterf ace. j 

3, 754 ResourceFactorylnterf ace . java 
3, 284 ResourceContractlnterf ace . j ava 
4,752 SystemMonitorlnterf ace, java 
5, 108 VocabularyToolboxInterf ace .java 
4,922 Vocabularylnterf ace. java 
105,260 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\cci\coreapi\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

112/16/99 06:19p 

il2/16/99 06:19p 

il2/16/99 06:19p 

^12/16/99 06:19p 



<DIR> 
<DIR> 



6 File(s] 



990 Entries 
65 Repository 
4 6 Root 
84 6 Template 
1,947 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\cci\coreproxy 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 



04 :33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 

6 File(s) 



<DIR> 
<DIR> 



<DIR> 



6.240 Connect ionFactorylnterf ace. java 

4.241 CoreProxylnterf ace . java 
CVS 

400 Makefile 
10,881 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\cci\coreproxy\CVS 
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test 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 176 Entries 

12/16/99 06:19p 67 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,135 bytes 

Directory of E: \e-speak-src_991217\platf orin\ES\src\java\net\espeak\in 
fra\cci\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 48 Entries 

12/16/99 06:19p 178 Entries. Log 

12/16/99 06:19p 57 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,175 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\cci\events 

12/06/00 04:33p <DIR> 
U2/06/00 04:33p <DIR> 

12/07/99 04:26p 6,417 CoreEvent . java 

-12/06/00 04:33p <DIR> CVS 

J12/07/99 04:26p 5,705 EventAttributeSet . java 

512/07/99 04:26p 7,891 EventList . java 

312/07/99 04:26p 14,456 Event. java 

112/07/99 04:26p 413 Makefile 

J 8 File(s) 34,882 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\cci\events\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 256 Entries 

12/16/99 06:19p 64 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,212 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\cci\exception 

12/06/00 04:33p <DIR> 
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test 


12/06/00 


04:33p 


<DIR> 




12/07/99 


04:26p 




2, 419 


12/06/00 


04:33p 


<DIR> 




12/07/99 


04:26p 




2,067 


12/07/99 


04:26p 




8,082 


12/07/99 


04:26p 




8, 668 


12/07/99 


04:26p 




2,404 


12/07/99 


04:26p 




1,839 


12/07/99 


04:26p 




2,356 


12/07/99 


04:26p 




2,375 


12/07/99 


04:26p 




7, 431 


12/07/99 


04:26p 




2,555 


12/07/99 


04:26p 




2,458 


12/07/99 


04:26p 




2,458 


12/07/99 


04:26p 




2,123 


12/07/99 


04:26p 




2,092 


12/07/99 


04:26p 




4,432 


^1 12/07/99 


04:26p 




2,204 


K 12/07/99 


04:26p 




2, 158 


yl2/07/99 


04:26p 




1,585 


ilJl2/07/99 


04:26p 




2, 454 


UJava 








012/07/99 


04:26p 




2,204 


i=an. java 








riJ12/07/99 


04:26p 




2,094 


. 12/07/99 


04:26p 




2,064 


? 707 / 9q 


04 • 9 fin 






11112/07/99 


04:26p 




2,016 


012/07/99 


04:26p 




2, 022 


im2/07/99 


04:26p 




2,152 


^312/07/99 


04:2 6p 




2, 542 


a2/07/99 


04:26p 




2,117 


a 

12/07/99 


04:26p 




2, 119 


12/07/99 


04:26p 




2, 056 


12/07/99 


04:26p 




2,035 


va 








12/07/99 


04:26p 




2,274 


12/07/99 


04:26p 




2,088 


12/07/99 


04:26p 




2, 118 


va 








12/07/99 


04:26p 




2, 453 


12/07/99 


04:2 6p 




2, 164 


12/07/99 


04:26p 




2, 112 


12/07/99 


04:26p 




2,332 


ava 








12/07/99 


04:26p 




2,216 


j ava 









CVS 



2,204 MultipleResolvedBindingExceptio 



2,216 UnrecoverableDeliveryException. 
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12/07/99 04:26p 

43 File(s) 



test 

2, 009 UnresolvedBindingException. java 
107,600 bytes 



Directory of E: \e-speak-src 991217\platform\ES\src\j ava\net \espeak\in 
f ra\cci\exception\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 2,545 Entries 

12/16/99 06:19p 67 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 3,504 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak;\in 
f ra\cci\export 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

112/07/99 04:26p 15,693 ExportFE. java 

112/07/99 04:26p 27,068 ExportContext . java 

112/07/99 04:26p 17,102 ImportContext . java 

'12/07/99 04:26p 397 Makefile 

f 7 File(s) 60,260 bytes 

-•• Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
If ra\cci\export\CVS 

112/06/00 04:33p <DIR> 

112/06/00 04:33p <DIR> 

512/16/99 06:19p 208 Entries 

12/16/99 06:19p 64 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,164 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\management 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 368 Makefile 

12/07/99 04:26p 3,081 ManagedServiceOpcodes . java 

5 File(s) 3,449 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
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test 



f ra\cci\management\CVS 



12/06/00 04:33p <DIR> 
12/05/00 04:33p <DIR> 

12/16/99 06:19p 111 Entries 

12/16/99 06:19p 68 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,071 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\cci\messaging 



TO f c\ r I r\r\ 


A A 


. O 0*-s 

: J Jp 


<DIR> 




• 


12/06/00 


04 


^ o o 

: 33p 


<DIR> 




• • 


iz/u //yy 


A / 


: z op 




4 , / U2 


BootstrapReply . java 


12/07/99 


04 


: 2 bp 




1 *"? /I A A 

17;r 492 


ChannelWriter . j ava 


□ 12/07/99 


A /I 

04 


: 2 bp 




23^ 263 


ChannelReader . j ava 


p 12/07/99 


f\ A 

04 


: 2 5p 




A A A C 1 

20, 951 


Channel . java 


12/07/99 


04 


: 2 bp 




T A AAA 

12 f 230 


ClientChannel . j ava 


i^j 12/06/00 


A A 

04 


o o 

; 33p 


<DIR> 




CVS 


ijj 12/07/99 


A A 

04 


: 26p 




A A A /I 

3, 284 


ESSerializable .java 


i2/u//9y 


A / 

U4 


: 2 bp 




b, ibb 


FI FOQueue . j ava 


i-"- 12/07/99 


A A 

04 


: 2 bp 




1 A Add 

13,488 


InboxMessageAtom. j ava 


:yi2/u//yy 


A /I 

04 


: 2 bp 






IVMCnannei . j ava 




n /I 


. z op 




7,410 


IVMQueue. java 


U12/07/99 


04 


:2 6p 




2, 697 


IVMRendezvous .java 


nJl2/07/99 


04 


:26p 




962 


Makefile 


012/07/99 


04 


:26p 




7, 804 


Message. java 


ffll2/07/99 


04 


:26p 




14, 287 


MessageAtom. java 


012/07/99 


04 


:26p 




34,717 


MessageRegistry . java 


i3l2/07/99 


04 


:26p 




22,555 


MessageOutputStream. java 


12/07/99 


04 


:26p 




22,914 


MessagelnputStream. java 


12/07/99 


04 


:26p 




6,647 


MessageBuf f eredStream. java 


12/07/99 


04 


:26p 




4,358 


MsgFilter . java 


12/07/99 


04 


:2 6p 




12, 195 


OutboxMessageAtom. java 


12/07/99 


04 


:26p 




4, 369 


PayloadRef erence . j ava 


12/07/99 


04 


:26p 




4, 380 


PayloadFromCore . j ava 


12/07/99 


04 


:26p 




3,467 


PayloadForCore . j ava 


12/07/99 


04 


:26p 




3,869 


Rendezvous . j ava 


12/07/99 


04 


:26p 




6,153 


Resourceinf o , j ava 


12/07/99 


04 


:26p 




3,800 


SystemMonitorHelper . j ava 


12/07/99 


04 


:26p 




12,380 


TCPChannel. java 


12/07/99 


04 


:26p 




3,229 


TCPRendezvous . java 






31 


File (s) 


289,067 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\cci\messaging\CVS 
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test 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:19p 

12/16/99 06:19p 

12/16/99 06:19p 

12/16/99 06:19p 

6 File(s) 



<DIR> 
<DIR> 

1,538 Entries 
67 Repository 
4 6 Root 
84 6 Template 
2,497 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\raetadata 



12/Oo/Uu 


04 


: J Jp 


<DIR> 




• 


1 9 / / nCi 
L/, / Uo/ UU 


n A 
u ^ 




<UiK> 






12/07/99 


04 


:26p 




12, 656 


Attribute . java 


12/07/99 


04 


:26p 




15,404 


Attr ibuteSet * j ava 


12/07/99 


04 


:26p 




9,786 


AttributePropertySet .java 


a 12/07/99 


04 


:26p 




21,375 


AttributeProperty , java 


:0 12/07/99 


04 


:26p 




10,960 


AttributePredicate . j ava 


%J 12/06/00 


04 


:33p 


<DIR> 




CVS 


iiJ 12/07/99 


04 


:26p 




29,182 


ESUID. java 


Ul 12/07/99 


04 


:26p 




704 


Makefile 


ri 12/07/99 


04 


: 26p 




1,756 


Matcherlnterf ace . j ava 


m2/07/99 


04 


: 26p 




3,760 


NamedOb j ect . j ava 


11112/07/99 


04 


:26p 




1,759 


Promoterlnterf ace . j ava 


n 12/07/99 


04 


:26p 




31,730 


ResourceSpecif icaticn. java 


1=^12/07/99 


04 


:26p 




6, 603 


ResourceDescription. java 


rUl2/07/99 


04 


:26p 




8,575 


RSD. java 


i3l2/07/99 


04 


:26p 




15, 618 


SearchRecipe , j ava 


iB12/07/99 


04 


:26p 




6, 406 


SearchPredicate. java 


012/07/99 


04 


:26p 




20, 342 


ValueType, java 


012/07/99 


04 


:26p 




59,374 


Value . j ava 



20 File(s) 255,990 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\cci\raetadata\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 929 Entries 

12/15/99 06:19p 65 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,887 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\naming 
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test 



1 9 /Dfi /DO 


U 4 








X ^ / \j \j / uu 


U T 




\ JJ X r\/ 




± ^ / \j f / y y 


U 4 








12/06/00 


04 


• 33n 


<DTR> 


TVS 


12/07/99 


04 


:26p 




27,188 ESName.java 


12/07/99 


04 


:25p 




7,868 LiteralName. java 


12/07/99 


04 


:26p 




441 Makefile 


12/07/99 


04 


:26p 




7,453 NameSearchPolicy . java 


12/07/99 


04 


:26p 




4,852 ResourceRef erence . java 






9 File(s; 


1 


50,871 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\cci\naming\CVS 



12/06/00 
12/06/00 
12/16/99 
112/16/99 
212/16/99 
112/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s; 



316 Entries 
64 Repository 
4 6 Root 

846 Template 
1,272 bytes 



J Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
ra\cci\security 



12/06/00 
=•^2/06/00 
yi2/06/00 
312/07/99 
012/07/99 
3l2/07/99 
312/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04 :26p 
04:26p 
04:26p 



<DIR> 
<DIR> 
<DIR> 



7 File(s) 



CVS 

2,228 Lockable . java 

5,335 LockedPermissions . java 

4,131 Lock. java 

394 Makefile 
13,088 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\cci\security\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 203 Entries 

12/16/99 06:19p 66 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,161 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\client 
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12/06/00 04:33p <DIR> 

12/06/00 04:33p <dir> 

12/06/00 04:33p <dir> 

12/06/00 04:33p <dir> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <dir> 

12/06/00 04:33p <dir> 

12/06/00 04:33p <DIR> 

12/07/99 04:26p 

12/06/00 04:33p <dir> 
10 File(s) 



test 



clientapi 
coreproxy 
corestubs 
CVS 

exception 
impl 
301 Makefile 
util 
301 bytes 



fr£ 

12/06/00 
12/06/00 
I 12/06/00 
] 12/07/99 
J 12/07/99 
J 12/07/99 
112/07/99 
112/07/99 
^12/07/99 
112/07/99 
12/07/99 
^^2/07/99 
J12/07/99 
112/07/99 
112/07/99 
112/07/99 
112/07/99 
12/07/99 



04 :33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :26p 
04 :26p 
04:26p 
26p 
26p 
26p 
26p 



<DIR> 
<DIR> 
<DIR> 



04 
04 
04 
04 



04:26p 
04:26p 

18 File{s) 



CVS 

2,613 ESContractlntf . java 

3,793 ESInboxIntf . java 

2,216 ESIntf.java 

3,218 ESKeylntf . java 

3,368 ESKeyRinglntf . java 
10,319 ESNameFramelntf . java 

3, 936 ESProtectionDomainlntf . java 

3,788 ESRemoteObjIntf . java 
13,674 ESRLIntf . java 

3,361 ESServicelntf . java 
40,793 ESShelllntf . java 

3,018 ESSysteraMonitorlntf . java 

3,339 ESViewIntf . java 

3,267 ESVocabularylntf . java 
674 Makefile 
101,377 bytes 



fra^ 

12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06: 19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



818 Entries 
70 Repository 
4 6 Root 
846 Template 
1,780 bytes 
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t 



12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/07/99 


04:26p 


33, 


12/07/99 


04:26p 




12/07/99 


04:26p 






6 File(s) 


H u 


Directory of E:\e-speak-src ! 




f ra\client\coreproxy\CVS 




12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:19p 




12/16/99 


06:19p 




12/16/99 


06:19p 




a 12/16/99 


06:19p 






6 File{s) 


1 


i^J Directory of E:\e-speak-src ' 


^^IZl 1 


UJf ra\client\corestubs 




h^l2/06/00 


04:33p <DIR> 




11112/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




hn2/07/99 


04:26p 


1 o 


rul2/07/99 


04:26p 


Q 

Of 


012/07/99 


04:26p 


r 

3/ 


W12/07/99 


04:26p 




□12/07/99 


04:26p 




Q12/07/99 


04:26p 




12/07/99 


G4:26p 


1 1 


12/07/99 


04:26p 


fc>. 


12/07/99 


G4:26p 


9, 


12/07/99 


04:26p 


42, 


12/07/99 


04:26p 


4, 


12/07/99 


04:26p 


3, 


12/07/99 


04:26p 


5, 


12/07/99 


04:26p 


5, 




17 File(s) 


133 



Directory of E:\e-speak-src_991217 
f ra\client\corestubs\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/16/99 06:19p 



est 



CVS 

,299 ESConnectionFactory . java 
074 ESCoreProxy . java 
390 Makefile 
,763 bytes 

\platf orni\ES\src\ j ava\net\espeak\in 



162 Entries 

70 Repository 

46 Root 
846 Template 
,124 bytes 

\platf orm\ES\3rc\ java\net\espeak\in 



CVS 

959 ImporterExporter . j ava 

599 Interf aceToCore . j ava 

527 KeyRing.java 

281 Key. java 

38 6 Mailbox. java 

642 Makefile 

94 5 Name Frame . j ava 

081 ProtectionDomain. java 

201 RepositoryView. java 

410 ResourceManipulation. java 

920 Resource Factory . java 

4 69 ResourceContract . j ava 

250 SystemMonitor . java 

396 Vocabulary . java 

, 066 bytes 

\platform\ES\src\ java\net\espeak\in 



755 Entries 
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test 

12/16/99 06:19p 70 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,717 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\client\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 48 Entries 

12/16/99 06:19p 104 Entries. Log 

12/16/99 06:19p 60 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,104 bytes 

i3 Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
:|5 f ra\client\exception 

i.yl2/06/00 04:33p <DIR> 
yl2/06/00 04:33p <DIR> 

1312/07/99 04:26p 2,505 CoreNotFoundException . j ava 

i.il2/06/00 04:33p <DIR> CVS 

i!J12/07/99 04:25p 409 Makefile 

12/07/99 04:26p 2, 937 UnexpectedExceptionException. ja 



M=va 



6 File{s) 5,851 bytes 



ill Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
i3f ra\client\exception\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 181 Entries 

12/16/99 06:19p 70 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,143 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\client\impl 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 5,506 ESContract . j ava 

12/07/99 04:26p 9,352 ESCoreManagementService. java 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
va 

12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
112/07/99 



04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
22 



File (s) 



test 

17,920 ESImporterExporter . java 

8,421 ESInbox.java 

7,753 ESKeyRing. java 

4,747 ESKey.java 

17, 4 40 ESManagedCoreManagedResource. ja 

23,204 ESName Frame. java 

8,391 ESProtectionDoraain. java 

10,068 ESRemoteObj . java 

36,740 ESRL.java 

3,837 ESService . java 

112,191 ESShell.java 

6,037 ESSystemMonitor. java 

13,322 ESView.java 

9,792 ESVocabulary. java 

8,090 ES.java 

738 Makefile 

16,647 StartService . java 
320,196 bytes 



I Directory of E:\e-speak-src_991217\platforni\ES\src\java\net\espeak\in 
lfra\client\impl\CVS 



^12/06/00 
112/06/00 
12/16/99 
-^=12/16/99 
J12/I6/99 
312/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 



<DIR> 
<DIR> 



1,011 
65 
46 
846 



Entries 

Repository 

Root 

Template 



6 File(s) 



1,968 bytes 



J Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\client\util 



12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 





10,093 CoreNameList . java 
CVS 

4,571 ESPOPInfo. java 
2,699 Ext ractException. java 
4 , 557 HelperMethods . java 
635 Makefile 
12,720 MessageState. java 
15, 524 MessageHandler , java 
11,781 MethodPermissionMap. java 
5,547 MsgldentityFilter . java 
5,919 MsgRSDFilter. java 
4,811 ParameterList . java 
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12/07/99 04:26p 
12/07/99 04:26p 
12/07/99 04:26p 

17 File(s) 



test 

5,598 PararaUnit . java 
2,340 Trace. java 
5,560 Userinf o. java 
93,355 bytes 



Directory of E: \e-speak:-src_991217\platform\ES\src\java\net\espeak\in 
fra\client\util\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:19p 

12/16/99 06:19p 

12/16/99 06:19p 

12/16/99 06:19p 

6 File(s) 



<DIR> 
<DIR> 

753 Entries 
65 Repository 
46 Root 

846 Template 
1,710 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 



3 f ra\core 










^112/06/00 


04 


: 33p 


<DIR> 




yi2/06/00 


04 


: 33p 


<DIR> 




UI12/06/00 


04 


: 33p 


<DIR> 


contract 


012/06/00 


04 


: 33p 


<DIR> 


CVS 


1-12/06/00 


04 


: 33p 


<DIR> 


exception 


11112/06/00 


04 


: 33p 


<DIR> 


export 


H 12/06/00 


04 


:33p 


<DIR> 


mailbox 


M12/07/99 


04 


:40p 




443 Makefile 


UI12/06/00 


04 


: 33p 


<DIR> 


management 


O12/06/00 


04 


: 33p 


<DIR> 


naming 


roi2/06/00 


04 


:33p 


<DIR> 


pd 


^312/06/00 


04 


: 33p 


<DIR> 


plugins 


a2/06/00 


04 


:33p 


<DIR> 


quota 


12/06/00 


04 


: 33p 


<DIR> 


repository 


12/06/00 


04 


: 33p 


<DIR> 


resource 


12/06/00 


04 


: 33p 


<DIR> 


router 


12/06/00 


04 


:33p 


<DIR> 


security 


12/06/00 


04 


: 33p 


<DIR> 


startup 


12/06/00 


04 


: 33p 


<DIR> 


sysmon 


12/06/00 


04 


: 33p 


<DIR> 


util 


12/06/00 


04 


: 33p 


<DIR> 


vocabulary 






21 


File (s) 


443 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\core\contract 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:40p 12,648 Contract . java 
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test 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 375 Makefile 

12/07/99 04:40p 2, 666 RegistrylF. java 

6 File{s) 15, 689 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\contract\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/15/99 06:19p 150 Entries 

12/16/99 06:19p 67 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,109 bytes 

Directory of E: \e-speak-src_991217\platf orra\ES\src\ java\net\espeak\in 
ifra\core\CVS 

a2/06/00 04:33p <DIR> 
112/06/00 04:33p <DIR> 

112/16/99 06:19p 48 Entries 

112/16/99 06:20p 289 Entries. Log 

^12/16/99 05:19p 58 Repository 

J12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

£ 7 File(s) 1,287 bytes 

3 Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
Of ra\core\exception 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:40p 2 , 531 AssertionFailedException . java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 372 Makefile 

5 File (s) 2, 903 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\exception\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 114 Entries 

12/16/99 06:19p 68 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,074 bytes 
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test 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\export 



12/06/00 


04: 


33p 


<DIR> 






12/06/00 


04: 


33p 


<DIR> 






12/06/00 


04: 


33p 


<DIR> 




CVS 


12/07/99 


04: 


40p 




5, 999 


ExportMessagelnputStream 


12/07/99 


04: 


40p 




42,803 


Exporter. java 


12/07/99 


04: 


4 Op 




8, 112 


FrameMapEntry . j ava 


12/07/99 


04: 


40p 




19,363 


ImportExportNames . java 


12/07/99 


04: 


40p 




26, 949 


ImporterExporter . java 


12/07/99 


04: 


4 Op 




55,249 


Importer . java 


12/07/99 


04: 


40p 




485 


Makefile 



10 File(s) 158,960 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
if ra\core\export\CVS 



112/06/00 
^2/06/00 
112/16/99 
112/16/99 
^=12/16/99 
112/16/99 



04:33p 
04:33p 
06: 19p 
06:19p 
06:19p 
06:19p 

6 File(s) 



<DIR> 
<DIR> 



386 Entries 
65 Repository 
46 Root 

84 6 Template 
1,343 bytes 



II Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
"Jfra\core\mailbox 



;;lL2/06/00 04:33p <DIR> 

:lL2/06/00 04:33p <DIR> 

12/07/99 04:40p 

12/07/99 04:40p 

12/07/99 04:40p 

12/07/99 04:40p 

12/06/00 04:33p <DIR> 

12/07/99 04:40p 

12/07/99 04:40p 

12/07/99 04:40p 

12/07/99 04:40p 

12/07/99 04:40p 

12 File(s) 



6,974 ChannelWriterThread. java 
2, 655 ChannelWriterDaemon . j ava 
6,985 ChannelThreadPool . java 
4,675 CoreChannel . java 
CVS 

10,995 Inbox. java 
527 Makefile 
2,344 MessageQueueltem. java 
5,321 MessageQueue. java 

10,818 Outbox.java 
51,294 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\mailbox\CVS 



12/06/00 04:33p <DIR> 
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test 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 489 Entries 

12/16/99 06:19p 66 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,447 bytes 

Directory of E: \e-speal<;-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\management 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 372 Makefile 

12/07/99 04:40p 16,612 ManagedAbstractResource. java 

5 File(s) 16,984 bytes 

I Directory of E: \e-speak:-src_991217\platform\ES\src\java\net\espeak\in 
If ra\core\management\CVS 

112/06/00 04:33p <DIR> 

J12/06/00 04:33p <DIR> 

J12/16/99 06:19p 113 Entries 

^12/16/99 06:19p 69 Repository 

J12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

^ 6 File(s) 1,074 bytes 

3 Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
Of ra\core\naming 

312/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:40p 5,107 Binding. java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 454 Makefile 

12/07/99 04:40p 23,229 MappingObject . java 

12/07/99 04:40p 94,368 NameFrame . java 

12/07/99 04:40p 8,209 NameSearchPolicyMatcher . java 

12/07/99 04:40p 5,580 PartialBinding. java 

9 File(s) 137,947 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\core\naming\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 324 Entries 
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12/16/99 
12/16/99 
12/16/99 



06:19p 
06:19p 
06:19p 

6 File(s) 



test 

65 Repository 
46 Root 
84 6 Template 
1,281 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak.\in 
f ra\core\pd 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:40p 
04: 40p 
04 :40p 
6 



<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 

377 Makefile 
30,042 ProtectionDomain. java 
5,997 WorkingSet . java 
36,416 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
ipfra\core\pd\CVS 



'"=112/06/00 
W12/06/00 
MJ12/16/99 
012/16/99 
i==*12/16/99 
^12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06: 19p 
6 



<DIR> 
<DIR> 



File (s; 



158 Entries 
61 Repository 
46 Root 

84 6 Template 
1,111 bytes 



f Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
ff ra\core\plugins 



312/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:40p 
04 : 40p 
04:40p 
04 : 40p 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 



<DIR> 
<DIR> 



9 File(s; 



CVS 

393 Makefile 
3,4 95 PluglnLoader . java 
1,776 PluglnlF. java 
4,548 Plugln.java 

secureboot 

testplugin 
10,212 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\plugins\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:19p 

12/16/99 06:19p 



<DIR> 
<DIR> 



200 Entries 
40 Entries. Log 
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test 

12/16/99 06:19p 66 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,198 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak;\in 
f ra\core\plugins\secureboot 

12/06/00 04:33p <DIR> 
12/06/00 04 :33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 4,395 SecureBoot . java 

4 File(s) 4,395 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\core\plugins\secureboot\CVS 

112/06/00 04:33p <DIR> 
112/06/00 04:33p <DIR> 

112/16/99 06:19p 55 Entries 

112/16/99 06:19p 77 Repository 

112/16/99 06:19p 46 Root 

112/16/99 06:19p 846 Template 

^ 6 File(s) 1,024 bytes 

Directory of E: \e-speak-src 991217\platform\ES\src\j ava\net \espeak\in 
=f ra\core\plugins\testplugin 

312/06/00 04:33p <DIR> 
312/06/00 04:33p <DIR> 

512/06/00 04:33p <DIR> CVS 

312/07/99 04:41p 1,915 TestPlugln. java 

4 File (s) 1, 915 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\plugins\testplugin\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 55 Entries 

12/16/99 06:19p 77 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,024 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\core\quota 
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12/06/00 


04 


: 33p 


<DIR> 


1z/Ud/U0 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:41p 




12/07/99 


04 


:41p 




12/07/99 


04 


:41p 




12/07/99 


04 


:41p 





7 File(s) 



Directory of E : \e-speak:-src_9 
fra\core\quota\CVS 



test 



CVS 

389 Makefile 
10,189 QuotaCheck. java 
14,951 QuotaSize. java 
25,082 Quota. java 
50,611 bytes 

1217\platform\ES\src\java\net\espeak\ 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



Directory of E:\e-speak-src 

w f ra\core\repository 



198 Entries 

64 Repository 

4 6 Root 
84 6 Template 
1,154 bytes 

_991217\platform\ES\src\java\net\espeak\ 



^f: 12/06/00 


04:33p 


<DIR> 


^^12/06/00 


04:33p 


<DIR> 


12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




yi2/07/99 


04:41p 




'2:12/07/99 


04:41p 




:il2/06/00 


04:33p 


<DIR> 


^-^12/07/99 


04 : 41p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:41p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 






20 


File (s) 



14,917 AbstractStore. java 

7,254 ActiveResourceOwners . 
14,960 CacheEntry. java 
10,740 CacheStats. java 
30,996 Cache. java 
CVS 

15, 703 DumpCor e . j a va 
jdbc 
771 Makefile 
mem 

17,870 RepositoryView, java 
4, 437 RepositoryReset .java 

24,681 RepositoryHandle. java 

30,283 Repository . java 

29,593 Scavenger. java 
3,452 StoreUnitsIF. java 
8,091 StoreUnitList . java 
4,335 StoreUnit .java 

218,083 bytes 



java 



Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\in 
fra\core\repository\CVS 
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test 

12/05/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 800 Entries 

12/16/99 06:20p 27 Entries. Log 

12/16/99 06:19p 69 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,788 bytes 



f ra\core\repository\ j dbc 


12/06/00 


04:33p 


12/06/00 


04:33p 


12/06/00 


04:33p 


12/07/99 


04:41p 


12/07/99 


04:41p 


012/07/99 


04:41p 


^012/07/99 


04 :41p 


'M12/07/99 


04 :41p 


^^12/07/99 


04:41p 


W12/07/99 


04:41p 


012/07/99 


04:41p 


^==^12/07/99 


04 : 41p 




12 File(s) 



<DIR> 
<DIR> 

<DIR> CVS 

14,197 JDBCRepositoryHandle. java 
29,056 JDBCHouseKeeping. java 
31,040 JDBCResourceState. java 
13, 912 JDBCResourceSpecification. java 
10,243 JDBCResourceLookup. java 
22, 361 JDBCResourceDescript ion. java 
17,317 JDBCSqlStrings. java 
16,847 JDBCStore. java 

576 Makefile 
155,549 bytes 

= Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\in 
= f ra\core\repository \ j dbc\CVS 

?12/06/00 04:33p <DIR> 

f 12/06/00 04:33p <DIR> 

=12/16/99 06:20p 526 Entries 

12/16/99 06:19p 74 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,492 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
r ra\core\repository\mem 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:41p 381 Makefile 

12/07/99 04:41p 7,591 MemStoreDB . java 

12/07/99 04:41p 14,777 MemStore . java 

6 File(s) 22,749 bytes 
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test 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\repository\mem\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File(s) 



150 Entries 
73 Repository 
4 6 Root 

846 Template 
1,115 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\resource 



12/06/00 
12/06/00 
12/07/99 
112/07/99 
312/06/00 
J12/07/99 
jl2/07/99 
J12/07/99 
312/07/99 
^^12/07/99 
J12/07/99 
12/07/99 
-12/07/99 



04:33p 
04:33p 
04:41p 
04:41p 
04:33p 
04:41p 
04:41p 
04:41p 
04:41p 
04:41p 
04: 41p 
04:41p 
04:41p 

13 File(s) 



<DIR> 
<DIR> 



<DIR> 



18,587 AbstractResource . j ava 
23, 240 CoreManagement Service. j ava 
CVS 

15,970 ESUIDFactory. java 
6,218 ExternalResource . java 
576 Makefile 

59,946 MetaResource. java 
2,800 MutableResourcelF. java 

14,087 ResourceType. java 

12, 611 ResourceSpecif ication. java 

17,749 ResourceFactory . java 

171,784 bytes 



Al Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
=3f ra\core\resource\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:20p 

12/16/99 06:20p 

12/16/99 06:20p 

12/16/99 06:20p 

6 File(s) 



<DIR> 
<DIR> 



568 Entries 
67 Repository 
4 6 Root 

84 6 Template 
1,527 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\router 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:41p 
04;41p 



<DIR> 
<DIR> 
<DIR> 



CVS 

369 Makefile 
2,282 Response . j ava 
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12/07/99 04:41p IT^OGO Router. java 

6 File(s) 19,711 bytes 

Directory of E: \e-spealc-src_991217\platform\ES\src\ java\net\espeak\in 
fra\core\router\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 146 Entries 

12/16/99 06:20p 65 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,103 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\security 



CVS 



□ 12/06/00 


04 


: 33p 


<DIR> 




^Ol2/06/00 


04 


: 33p 


<DIR> 




■^12/06/00 


04 


: 33p 


<DIR> 




W12/07/99 


04 


:41p 




1,824 


W12/07/99 


04 


:41p 




10, 631 


012/07/99 


04 


:41p 




7,550 


12/07/99 


04 


: 41p 




456 


^■^^2/07/99 


04 


:41p 




24,731 


r 12/07/99 


04 


:41p 




9, 913 


t^:i2/07/99 


04 


:41p 




3, 095 



Makefile 



10 File(s) 58,200 bytes 

^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
::fra\core\security\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 355 Entries 

12/16/99 06:20p 67 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,314 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\ startup 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:41p 12,653 CoreArgs . java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:41p 414 Makefile 
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12/07/99 04:41p 
12/07/99 04:41p 
12/07/99 04:41p 
12/07/99 04:41p 

9 File(s) 



test 

2^166 pingServer . real 
5^724 Server. java 
6,003 StartESCore. java 
35,87 6 StartupCore . java 
62, 836 bytes 



Directory of E:\e-speak-src 991217\platform\ES\src\ j ava\net \espeak\in 
f ra\core\startup\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 304 Entries 

12/16/99 06:20p 66 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,262 bytes 



1 Directory of E; \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
if ra\core\sysmon 



112/06/00 
fl2/06/00 
112/06/00 
^12/07/99 
112/07/99 



04:33p 
04:33p 
04:33p 
04:41p 
04:41p 
5 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

357 Makefile 
i,817 SysteiiiMonitor . java 
9,174 bytes 



J Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
If ra\core\sysmon\CVS 



312/06/00 
312/06/00 
12/16/99 
12/16/99 
12/15/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



103 Entries 
65 Repository 
4 6 Root 

84 6 Template 
1,060 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\util 



12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:41p 




24, 650 


CoreHelper . j ava 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:41p 




35, 464 


Logger. java 


12/07/99 


04 


:41p 




395 


Makefile 


12/07/99 


04 


:41p 




7,463 


ServiceRegistry 
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7 File{s) 



test 

67,972 bytes 



Directory of E : \e-speak-src_991217\platf orin\ES\src\ java\net\espeak\in 
fra\core\util\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 205 Entries 

12/16/99 06:20p 63 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,160 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\core\ vocabulary 



12/06/00 


04 


: 33p 


<DIR> 








312/06/00 


04 


:33p 


<DIR> 








yl2/06/00 


04 


:33p 


<DIR> 






CVS 


'112/07/99 


04 


:41p 




24, 


331 


Expression. java 


^^Jl2/07/99 


04 


:41p 




3, 


717 


ExprNode . j ava 


W12/07/99 


04 


:41p 




9, 


836 


LiteralNode . j ava 


□12/07/99 


04 


:41p 






480 


Makefile 


^^2/07/99 


04 


:41p 




19, 


310 


OpNode. java 


nJl2/07/99 


04 


:41p 




5, 


454 


PropertyNode . j ava 


12/07/99 


04 


:41p 




17, 


130 


Tokenizer . java 


!":a2/07/99 


04 


:41p 




16, 


969 


Vocabulary . j ava 



^ 11 File(s) 97,227 bytes 

Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\in 
;;fra\core\ vocabulary \CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 408 Entries 

12/16/99 06:20p 69 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,369 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fraXCVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 48 Entries 

12/16/99 06:20p 78 Entries. Log 

12/16/99 06:19p 53 Repository 
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12/16/99 06:19p 
12/16/99 06:19p 

7 File(s) 



test 

46 Root 
846 Template 
1,071 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 



f raXintercorecom 






12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 


conf actory 


12/06/00 


04:33p 


<DIR> 


connectors 


12/06/00 


04:33p 


<DIR> 


CVS 


12/06/00 


04:33p 


<DIR> 


esip 


12/07/99 


04:26p 




303 Makefile 


12/06/00 


04. -33? 


<DIR> 


proxy 


12/06/00 


04:33p 


<DIR> 


stacks 


12/06/00 


04:33p 


<DIR> 


util 




10 


File (s) 


303 bytes 



I Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
-fra\intercorecom\conf actory 



-112/06/00 
n2/06/00 
il2/07/99 
12/07/99 
'=12/06/00 
^12/07/99 
fava 

312/07/99 
J12/O7/99 
42/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 

04:26p 
04:2 6p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :33p 
04:26p 
04:33p 
04:26p 

17 File(s; 



<DIR> 
<DIR> 



<DIR> 



<DIR> 



<DIR> 



7,252 CFEventPublisher . java 
6,288 CFStatistics. java 

CO 

2, 138 CommunicationManagerException. j 

65,437 CommunicationManager. java 
7,656 ConnectionRegistry . java 
3,671 ConnectionEntry . java 
3,309 ConnFactoryTags . j ava 
6,409 ConnFactorySM. java 
4, 682 ConnFactoryInf o . j ava 
2,133 CreateProxyException. java 
CVS 

502 Makefile 
policy 
3,523 Stat sUpdate. java 
113,000 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\intercorecom\conf actory \co 

12/06/00 04 :33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:26p 6,484 ConnectionObject . j ava 
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test 

12/07/99 04:26p 2,892 Connectioninf ointf . java 

12/06/00 04:33p <DIR> cVS 

12/07/99 04:26p 2,515 SerializationException . java 

12/07/99 04:26p 5,225 TCPConnectionInf o . j ava 

7 File(s) 17,116 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\intercorecora\conf actory\co\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 244 Entries 

12/16/99 06:20p 80 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,216 bytes 

I Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
yf ra\intercorecom\confactory\CVS 

^12/06/00 04:33p <DIR> 
«12/06/00 04:33p <DIR> 

□12/16/99 06:20p 694 Entries 

:-12/16/99 06:20p 28 Entries. Log 

yi2/16/99 06:20p 77 Repository 

^ 12/16/99 06:20p 46 Root 

r:12/16/99 06:20p 846 Template 

jf 7 File (s) 1, 691 bytes 

J Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
j;fra\intercorecom\conf actoryXpolicy 



CVS 

13,446 Negotiator . java 
14,105 NegotiationPolicy. java 
4,684 NegotiationOffer. java 
2, 348 NegotiationFailedException. java 
3,337 SecurityPolicy. java 
8 File(s) 37,920 bytes 

Directory of E : \e-speak-src_991217\platf oriii\ES\src\ j ava\net\espeak\in 
fra\intercorecom\confactory\policy\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 296 Entries 



12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


: 26p 




12/07/99 


04 


: 26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 
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12/16/99 
12/16/99 
12/16/99 



06:20p 
06:20p 
06:20p 

6 File(sl 



test 

84 Repository 
46 Root 
84 6 Template 
1,272 bytes 



Directory of E : \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\intercorecom\connectors 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
112/07/99 
:i2/07/99 
il2/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

12 File(s) 



<DIR> 
<DIR> 



<DIR> 



7,732 ConnectorManager . java 
6,183 ConnectorDesc. java 
4,495 Connector . java 
CVS 

5,514 DataConnector . java 
3,714 ListeningConnector . java 
557 Makefile 
13,703 TcpDataConnector . java 
7,334 TcpListeningConnector . java 
6,420 TcpTunnelConnector . java 
55, 652 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
^f ra\intercorecora\connectors\CVS 



12/06/00 
■12/06/00 
'^2/16/99 
112/16/99 
^12/16/99 
^12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File(s; 



508 Entries 
77 Repository 
4 6 Root 

84 6 Template 
1,477 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\intercorecom\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04 : 33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File(s) 



48 Entries 
99 Entries. Log 
66 Repository 
4 6 Root 
84 6 Template 
1,105 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\intercorecom\esip 
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12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




12/07/99 


04 


: 2 6p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/08/99 


03 


:16p 





9 File(s) 



test 

CVS 

3,548 ESIPControlMessage. java 
5,727 ESIPExportMessage . java 
4,267 ESIPHeader. java 
4,123 ESIPMessage. java 
2,126 ESIPPayload. java 

461 Makefile 
20,252 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\intercorecoin\esip\CVS 



12/06/00 
12/06/00 
12/16/99 
312/16/99 
012/16/99 
^112/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



325 Entries 
71 Repository 
46 Root 

84 6 Template 
1,288 bytes 



□ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
i"-fra\ inter corecom\proxy 



12/06/00 
=n2/06/00 
U12/06/00 
3l2/07/99 
B12/07/99 
3x2/07/99 
=112/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04 :33p 
04 :33p 
04:33p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
12 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

2, 166 EbyteArrayOutput St ream. java 
533 Makefile 
12,68 9 ProxyAPIHandler. java 
27,950 ProxyExportHandler . j ava 

8,861 ProxyHelper . java 

9, 709 Proxy ImportHandler . j ava 
36, 159 Proxy . j ava 
26,195 StateMgr. java 

3,882 Timeouts . java 
128,144 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\intercorecom\proxy\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 489 Entries 

12/16/99 06:20p 72 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 
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6 File{s) 



test 
1,453 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\ espeak\in 



fra\intercorecom\s tacks 




12/06/00 


04:33p 


<DIR> 


12/05/00 


04:33p 


<DIR> 


12/06/00 


04 :33p 


<DIR> 


12/07/99 


04 :26p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 






8 File(s) 





CVS 

5,443 LayerFactory. java 
layers 
457 Makefile 
4,429 StackBuilder. java 
14,775 Stack. java 
25,104 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\intercorecom\stacks\CVS 

! 12/06/00 04:33p <DIR> 

U2/06/00 04:33p <DIR> 

; 12/16/99 06:20p 203 Entries 

: 12/16/99 06:20p 16 Entries. Log 

^2/16/99 06:20p 73 Repository 

: 12/16/99 06:20p 46 Root 

^'12/16/99 06:20p 846 Template 

7 File(s) 1,184 bytes 

; Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
; fra\intercorecom\stacks\layers 

J 12/06/00 04:33p <DIR> 

'12/06/00 04:33p <DIR> 

12/07/99 04:26p 2,166 CILayer.java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 3,461 Layerlntf . j ava 

12/07/99 04:26p 4,834 Layer. java 

12/07/99 04:26p 464 Makefile 

12/07/99 04:26p 7,071 NameAuthenticationLayer . j ava 

12/07/99 04:26p 2,221 TransportLayer . j ava 

9 File(s) 20,217 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\intercorecom\ stacks Mayers \CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 316 Entries 

12/16/99 06:20p 80 Repository 
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test 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,288 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\intercorecoin\util 



12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:26p 




3,820 


CondVar . java 


12/07/99 


04 


:25p 




7,348 


ConnectionOb j ectFileReader 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




4,748 


Header .java 


12/07/99 


04 


:26p 




3,180 


Lock. java 


12/07/99 


04 


:26p 




439 


Makefile 


12/07/99 


04 


:2 6p 




3,276 


Synchronizer .java 


12/07/99 


04 


:26p 




3,090 


Verif yDomain. java 



10 File(s; 



25,901 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
^Atra\intercorecom\util\CVS 



^A2/06/00 
H12/06/00 
ii.2/16/99 
12/16/99 
A2/16/99 
^i{L2/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



367 Entries 
71 Repository 
46 Root 

845 Template 
1,330 bytes 



~:: Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
•~£ra\xml 



12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:2 6p 




12/07/99 


04 


: 26p 




12/07/99 


04 


:2 6p 




12/07/99 


04 


:26p 




12/07/99 


04 


:2 6p 




12/07/99 


04 


:26p 




12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


:26p 




12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


: 2 6p 




12/07/99 


04 


:26p 




12/06/00 


04 


:33p 


<DIR> 



CVS 

2,931 ESXMLDecoderlntf . java 
49,369 ESXMLDecoder. java 
2,453 ESXMLEncoderlntf . java 
6,183 ESXMLEncoder. java 
2,761 ESXMLShelllntf . java 
20,001 ESXMLShell. java 
IE5 

515 Makefile 

schema 8 
7,355 XMLApp.java 
4,425 XMLNameList. java 

xml server 



Page 66 



15 File(s) 



test 

95,993 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\i 
fra\xml\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File(s) 



481 Entries 
49 Entries. Log 
57 Repository 
46 Root 

846 Template 
1,479 bytes 



Directory of E:\e-speak-src 991217\platf orm\ES\src\java\net\espeak\in 
fra\xml\IE5 



112/06/00 
J12/06/00 
U2/06/00 
^12/07/99 
1^12/07/99 
^12/07/99 
'12/07/99 
^12/07/99 
12/07/99 
'12/07/99 
fl2/07/99 
fl2/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

12 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

854 e-speak_logo.gif 
1,792 lookup.htm 
3,320 lookup. js 

628 Readme.txt 
1,623 register.htm 
3,226 register. js 
3,631 response. js 
1,757 vocab.htm 
3,873 vocab.js 
20,704 bytes 



' Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\xml\IE5\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 

6 File{s) 



<DIR> 
<DIR> 



432 Entries 
61 Repository 
4 6 Root 

84 6 Template 
1,385 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
f ra\xml\schemas 



12/06/00 04:33p 
12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
<DIR> 



CVS 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
8 



File(s; 



test 

4,405 es-basic . xsd 
368 es-lookup.xsd 
419 es-register . xsd 
589 es-response . xsd 
498 es-vocab.xsd 
6,279 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\xml\schemas\CVS 



12/05/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 



<DIR> 
<DIR> 



6 File(s; 



255 Entries 
65 Repository 
46 Root 

846 Template 
1,212 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
1 f ra\xml\xmlserver 



il2/06/00 
a2/06/00 
=12/06/00 
il2/07/99 
12/07/99 
=12/07/99 
^12/07/99 
il2/07/99 



04:33p 
04:33p 
04:33p 
04 : 2 6p 
04:26p 
04:26p 
04:26p 
04:26p 



<DIR> 
<DIR> 
<DIR> 



8 File(s) 



CVS 

5,291 ESXMLHttp. java 

3,218 ESXMLServerThread. java 

3,397 ESXMLServer. java 

314 Makefile 
8,305 TestServerApp. java 
20,525 bytes 



* Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\xinl\xinlserver\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 



<DIR> 
<DIR> 



6 File(s; 



266 Entries 
67 Repository 
4 6 Root 

846 Template 
1,225 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ je 
si 



12/06/00 
12/05/00 
12/07/99 



04:33p 
04:33p 
04:26p 



<DIR> 
<DIR> 



7,741 AppSessionlDFilter . java 
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test 



xz / u / / y y 


U4 : zop 


9, 404 


Iz / U / / y y 


A yi - o 

04 : 26p 


9, 098 


iz/ Uo/ U(J 


A /I . O O — 

04 : 33p 


<DIR> 


iz / u / / y y 


04 : 2 bp 


3, 496 


io /n'7 / nn 

iz/u / /yy 


A j1 _ O 

04 : 26p 


55, 605 


io / n^ / nn 

1z/(j7/99 


04 : 26p 


38, 691 


in /m / nn 

iz/U //yy 


A yi A /" 

04 : 2 bp 


8,783 


TO / n'7 /nn 

iz/Q7/ 99 


04 : 26p 


47,370 


lz/07/99 


04 : 26p 


2,293 


12/07/99 


04 : 26p 


17,372 


12/07/99 


04 : 2 6p 


4, 455 


12/07/99 


04 : 25p 


3, 690 


12/07/99 


04 : 2 6p 


9, 610 


12/07/99 


04 : 26p 


17, 621 


1 n / A^ i r\ r\ 

12/07/99 


04 : 2 5p 


2,226 


12/07/99 


04 : 26p 


9,288 


12/07/99 


04 : 2 6p 


22, 360 


:,.a2/07/99 


04 :26p 


7,475 


=iijl2/07/99 


04 :26p 


5,151 


-il2/07/99 


04 : 26p 


2,374 




04 :2 6p 


4, 939 


=jil2/07/99 


04 : 26p 


7,132 


;^-12/07/99 


04 : 2 6p 


2, 478 


;jl2/07/99 


04 :26p 


12,058 


-^d2/07/99 


04 :26p 


11,751 


12/07/99 


04 : 2 6p 


18, 190 


;;;";12/07/99 


04 : 26p 


47,841 


'j;:12/07/99 


0 4 : 2 6p 


6,580 


=-fl2/07/99 


04 : 2 6p 


8, 475 


iJlilO / A""? / AA 

•^;;^12/07/99 


04 : 26p 


6,541 


-?;;;rlZ/07/99 


04 : 26p 


7, 474 


■--iz / (J // 99 


04 : 2 6p 


7, 914 


TO / A""? / r\ r\ 

12/07/99 


04 : 2 6p 


44, 996 


iz/u //yy 


04 : 2 6p 


12, 517 


T o / r\n / C\ c\ 
LZ / \j 1 / 33 


04 : 26p 


6, 168 


12/07/ 99 


04 : 2 6p 


55, 878 


iz/U //99 


A /t A ^ 

04 : 26p 


3, 806 


1 o /ni / r\ r\ 


04 : 26p 


6,331 


T O / Oil / nn 

Iz/U //99 


04 : 26p 


5,295 


TO /no /nn 

12/ 07/99 


04 : 26p 


2,228 


TO / r\n / Ci n 

12/07/99 


04 : 26p 


5, 026 


TO /no / nn 


04 : 26p 


9,790 


12/07/99 


04 :26p 


1 Q7 7 


12/07/99 


04:26p 


2, 633 


12/07/99 


04:26p 


4, 917 


12/07/99 


04:26p 


14,917 


12/07/99 


04:26p 


2,388 


12/07/99 


04:26p 


3,755 
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ClassDependencyFinder . java 

ClassFinder . java 

CVS 

ESContract . j ava 
ESAbstractFinder . java 
ESAbstractElement . j ava 
ESAccessRight . java 
ESAccessorStub . j ava 
ESAccessorHandle . java 
ESAccessor . java 
ESAppSessionlD. java 
ESAssert . java 
ESAttribute . j ava 
ESBaseServiceStub. java 
ESBaseService. java 
ESBaseQuery . java 
ESBaseDescription. java 
ESServiceDescription . j ava 
ESVocabularyElement . j ava 
ESService. java 
ESCallbacklntf . java 
ESCallbacklmpl . j ava 
ESCloneable . j ava 
ESCommunity . j ava 
ESConfigurat ion. java 
ESConnector . j ava 
ESConnect ion. java 
ESConstants . java 
ESContractStub . j ava 
ESContractFinder . j ava 
ESContractElement . j ava 
ESContractDescription. java 
ESServiceElement . j ava 
ESServiceContext . java 
ESFolderFinder . java 
ESFolder. java 
ESHashMap. java 
ESHelper - java 
ESImplProxy . java 
ESIntrospectionlntf . java 
ESIntrospectionlmpl . j ava 
ESList . java 
ESManagement Int f . j ava 
ESMessageRegistrylntf . java 
ESMessage . j ava 
ESMPM. java 
ESNameFactory . j ava 
ESQuery. java 



iz/07/99 


04 


: 2 6p 


Iz/U //99 


04 


: 26p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


i3l2/07/99 


04 


:26p 


^Cl2/07/99 


04 


: 2 6p 


~ iz/u / / yy 


O A 

04 


: 2 bp 


W12/07/99 


04 


:26p 


W12/06/00 


04 


: 33p 


□ 12/07/99 


04 


: 26p 


i=*12/07/99 


04 


: 26p 


iyi2/05/00 


04 


: 33p 



<DIR> 



<DIR> 



76 File(s) 



test 

3,189 ESRunnable. java 

13,633 ESScope.java 
2,564 ESSecuritylntf . java 
8,64 9 ESServiceStub. java 

18,986 ESServiceMessenger. java 

21,090 ESServiceHandler. java 
8,170 ESServiceFinder. java 
2,507 ESSessionlntf . java 
4,693 ESSessionlmpl. java 

18,154 ESStartService. java 
2,223 ESStubFactorylntf . java 

6.867 ESStubFactorylmpl. java 
4,213 ESThread. java 

4,909 ESUniqList. java 
6,042 ESUserCredential. java 
20,618 ESVocabularyDescription. 

2.868 ESVocabulary . j a va 

8 , 682 ESVocabularyStub . j ava 
6,647 ESVocabularyFinder . java 
3,243 ESXMLFile. java 
5,276 ESXMLQuery. java 
event 

5,290 GenericClassLoader . java 
2,169 Makefile 

management 
788,790 bytes 



java 



; Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\i 
^si\CVS -' 



^12/06/00 
^12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
05:20p 
7 



<DIR> 
<DIR> 



File (s) 



3,944 Entries 

35 Entries. Log 
52 Repository 
4 6 Root 
846 Template 
4, 923 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\j 
sixevent 



12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:33p 
04 :26p 
04 :26p 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



coredist 
CVS 

15,259 ESCoreSubscriber. java 
2,359 ESCoreListenerlntf . java 
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/ u / / y y 


04 


: 26p 


iz / (J / / y y 


n /I 

04 


A /" 

: 2 6p 


iz/U / / y9 


04 


A 

:26p 


iz/u // yy 


A A 

04 


: 2 6p 


iz/ u / / y y 


A j1 

04 


:26p 


1^/07/99 


04 


: 26p 


iz/u //y y 


A A 

04 


: 2 6p 


iz/u //yy 


A A 

04 


: 26p 


10 I c\ r I r\r\ 


A /I 

04 


: 33p 


IZ / U b/ Uu 


A A 

u4 


A A 

; 33p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/06/00 


04 


: 33p 






21 



<DIR> 
<DIR> 



<DIR> 



test 
14, 425 
6,481 
2,777 
5, 660 
2,589 
20,502 
17, 999 
2, 059 



730 
5,740 
4,843 
5,769 

107,193 



ESDistributor . j ava 
ESListenerStub, java 
ESListenerlntf . java 
ESPublisherStub . j ava 
ESPublisherlntf . java 
ESPublisher . j ava 
ESSubscriber . j ava 
EventException . j ava 
irapl 
intf 

Makefile 

Publisherlnfo .java 
ResultSetEntry. java 
ResultSet .java 
util 
bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\je 
5i\event\coredist ^ -' 



J12/06/00 
J12/06/00 
^^2/07/99 
=12/06/00 
^12/07/99 
12/07/99 
'12/07/99 
fl2/07/99 
fl2/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
9 



<DIR> 
<DIR> 

<DIR> 



File (si 



6,908 CoreSubProfile. java 
CVS 

3,621 ESCoreListenerStub. java 
4,352 ESCoreDistributorStub. java 
3,343 ESCoreDistributorlntf . java 
8,886 ESCoreDistributorlmpl. java 

485 Makefile 
27,595 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\je 
i\event\coredist\CVS \ h jv\jc 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



353 Entries 
67 Repository 
4 6 Root 

846 Template 
1,312 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ie 
i\event\CVS \j 



si\event\CVS 

12/06/00 04:33p 
12/06/00 04:33p 
12/16/99 06:20p 



<DIR> 
<DIR> 



772 Entries 
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12/16/99 
12/16/99 
12/16/99 
12/16/99 



06:20p 
06:20p 
06:20p 
06:20p 
7 



File(s) 



test 

60 Entries. Log 
58 Repository 
4 5 Root 
846 Template 
1,782 bytes 



si\event\impl 




12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/07/99 


04:26p 




ava 






12/07/99 


04:26p 




12/07/99 


04:26p 




O12/07/99 


04:26p 




^012/07/99 


04:26p 




^^12/07/99 


04:26p 






10 


File (s) 



CVS 

11,967 DistributorStore. java 
10,316 ESEventServiceCoraponentHelper . j 

17, 224 ESEventServiceComponent . java 
12, 805 ESEventDistributorlmpl .java 
510 Makefile 
5,724 RegisterEventABI. java 
4,909 SubsDet.java 
63,455 bytes 

f Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\je 
;;si\event\impl\CVS 



12/06/00 
'12/06/00 
fl2/16/99 
fl2/16/99 
a2/16/99 
fl2/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



413 Entries 
63 Repository 
4 6 Root 
846 Template 
1,368 bytes 



si\event\intf 


12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/06/00 


04 


:33p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


y. java 






12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


ry . java 






12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 



<DIR> 
<DIR> 
<DIR> 



CVS 

10,752 ESDistributorStub. java 
3,317 ESDistributorlntfMessageRegistr 

4,324 ESDistributorlntf . java 
11,7 92 ESEventServiceStub. java 
3, 320 ESEventServicelntfMessageRegist 

2,8 65 ESEventServicelntf . java 
4, 945 ESListenerlntfMessageRegistry. j 
Page 72 



test 



ava 

12/07/99 04:26p 
java 

12/07/99 04:26p 

12 File(s) 



3, 34 6 ESPublisherlntfMessageRegistry . 

613 Makefile 
45,274 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ie 
si\event\intf\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File(s) 



578 
63 
46 

846 
1,533 



Entries 

Repository 

Root 

Template 
bytes 



[ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ie 
;si\event\util 



'=^=12/06/00 


04:33p 


<DIR> 


W12/O6/OO 


04:33p 


<DIR> 


012/07/99 


04:26p 




^42/06/00 


04:33p 


<DIR> 


^^12/07/99 


04:26p 




:^ 12/07/99 


04:26p 




!::l2/07/99 


04:26p 




^.yi2/07/99 


04:26p 




yi2/07/99 


04:26p 




^12/07/99 


04:26p 




^^12/07/99 


04:26p 




^12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 






14 File 


(s) 



4,686 CoreEventPredicate. java 
CVS 

5,530 EventContext . java 
3,783 Event DataTypes. java 
8,788 EventMapEntry . java 
8,550 EventMap. java 
8,253 EventPredicate. java 
5,526 Id. java 
6,323 Inputinf o . java 

551 Makefile 
6,391 PubProfile. java 
9,576 SubProf ile. java 
67,957 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ie 
si\event\util\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



578 
63 
46 

846 
1,533 



Entries 

Repository 

Root 

Template 
bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\je 

Page 73 



si \management 



test 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
ry . java 
12/07/99 
12/07/99 
12/07/99 
112/07/99 
^12/07/99 
112/07/99 
^12/07/99 
112/07/99 
^12/07/99 
:i2/07/99 
^12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:25p 
04:26p 
04:26p 
04:26p 

23 File(s) 



<DIR> 
<DIR> 



<DIR> 



12, 092 AbstractManagedService. java 
2, 703 CoreConnectionException. java 
CVS 

2, 672 IllegalStateTransition.esidl 

2, 415 IllegalStateTransition. java 

1,135 Makefile 
12,899 ManagedServicelntf . esidl 
15,798 ManagedServiceStub. java 

2, 306 ManagedServicelntfMessageRegist 

12,899 ManagedServicelntf .java 
3,496 ManageableService . java 
2,680 NoSuchVariableNarae. esidl 
2,395 NoSuchVariableName. java 
1,748 ResourceEntry. esidl 
2,800 ResourceEntry. java 
6,580 ServiceContext . java 

6.096 SimpleManagedService. java 
1,770 VariableType. esidl 

3.097 VariableType. java 
1,965 VariableEntry .esidl 
2,734 VariableEntry . java 

100,280 bytes 



:: Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\je 
^;si\management\CVS 



^'12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:20p 

12/16/99 06:20p 

12/16/99 06:20p 

12/16/99 06:20p 

6 File(s) 



<DIR> 
<DIR> 



1,191 Entries 

53 Repository 
4 6 Root 
84 6 Template 
2, 146 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
rvices 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:26p 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 

<DIR> 
<DIR> 



advertise 
14 9 compile.bat 
CVS 

events 



Page 74 



12/07/99 
12/06/00 
12/06/00 



04:26p 
04:33p 
04:33p 
9 



<DIR> 
<DIR> 



File (s) 



test 

269 Makefile 
management 
tunnel 
418 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\£ 
rvices\advertise 



12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/06/00 
^12/06/00 
^12/07/99 
112/07/99 
(12/07/99 
^12/06/00 
^2/06/00 
=12/06/00 
^2/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:33p 
04:33p 
04:33p 
04:33p 
17 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 



<DIR> 
<DIR> 
<DIR> 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



File (s) 



agents 
bin 

clientapi 
1,055 compile.bat 
143 co.MYCOs 
CVS 

discovery 

exception 
325 Makefile 
668 makefile. release 
131 object-class-definition 

query_parser 

util 

ypcommon 
ypserver 
2,322 bytes 



j Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\s 
jrvices\advertise\agents 



AdvLSAgent . j a va 

BackendAgentlntf . java 
CVS 

LDAPDirAgent . j ava 
Makefile 

ProxySocketFactory. java 
72,183 bytes 



-^12/06/00 


04 


: 33p 


<DIR> 






■»^12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


: 26p 




14, 


434 


12/07/99 


04 


:26p 




5, 


019 


12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


:26p 




45, 


917 


12/07/99 


04 


: 26p 






441 


12/07/99 


04 


:26p 




6, 


372 



8 File(s) 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\j 
rvices\advertise\agents\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
05:20p 
06:20p 
06:20p 



<DIR> 
<DIR> 



272 Entries 
73 Repository 
4 6 Root 
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12/16/99 06:20p 

6 File(s) 



test 

846 Template 
1,237 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices\advertise\bin 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


: 26p 




607 


runas_ldap . bat 


12/07/99 


04 


: 26p 




640 


runas_ldap 


12/07/99 


04 


:26p 




599 


runas_noldap 


12/07/99 


04 


:26p 




580 


runas noldap.bat 


12/07/99 


04 


:26p 




585 


runas_ldap_s 


12/07/99 


04 


:26p 




549 


runas Idap s.bat 


12/07/99 


04 


:26p 




585 


runas_ldap_i_s 


12/07/99 


04 


:25p 




549 


runas Idap i s.bat 


=12/07/99 


04 


:26p 




673 


runas_ldap i 


112/07/99 


04 


:26p 




635 


runas_ldap_i . bat 






13 


File (s) 


6,002 


: bytes 



Directory of E : \e-speak;-src_991217\platf orm\ES\src\ java\net\espeak\se 
'4:vices\advertise\bin\CVS 

^42/06/00 04:33p <DIR> 

^12/06/00 04:33p <DIR> 

:l2/16/99 06:20p 513 Entries 

]42/16/99 06:20p 70 Repository 

"42/16/99 06:20p 46 Root 

3.2/16/99 06:20p 846 Template 

^ 6 File(s) 1,475 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\advertise\clientapi 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 23,009 ESADServicelnterf ace . java 

12/07/99 04:26p 376 Makefile 

5 File(s) 23,385 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\advertise\clientapi\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 110 Entries 

Page 7 6 



12/16/99 06:20p 
12/16/99 06:20p 
12/16/99 06:20p 

6 File(s) 



test 

7 6 Repository 
4 6 Root 
84 6 Template 
1,078 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\ 
rvices\advertise\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:21p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File (s) 



254 Entries 
158 Entries. Log 

66 Repository 

46 Root 
84 6 Template 
1,370 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
rvices\advertise\discovery 



^2/06/00 Q4:33p <DIR> 

^12/06/00 04:33p <DIR> 

^12/07/99 04:26p 

=12/07/99 04:26p 

^12/07/99 04:26p 

12/07/99 04:26p 

:12/07/99 04:26p 

^12/07/99 04:26p 

^12/07/99 04:26p 

J12/07/99 04:26p 

^12/07/99 04:26p 

^12/07/99 04:26p 

12/06/00 04:33p <DIR> 

12/07/99 04:26p 

14 File(s) 



4,005 AdvDscvMsgBag. java 
1,992 AdvDscvMsg. java 
4,022 AdvIncomingDscvRqst . java 
4,575 AdvIncomingDscvRply . java 
12, 183 AdvMcastSenderReceiver . java 
3,810 AdvOutgoingDscvRqst . java 
7,247 AdvOutgoingDscvRply . java 
4,524 AdvSLPOutgoingMsg. java 
3,336 AdvSLPMsg. java 
7,123 AdvSLPIncomingMsg . java 
CVS 

640 Makefile 
53,457 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\ 
rvices\advertise\discovery\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 



<DIR> 
<DIR> 



6 File(s: 



632 Entries 
76 Repository 
4 6 Root 

84 6 Template 
1,600 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 

Page 77 



rvices\advertise\exception 



test 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
9 



<DIR> 
<DIR> 



<DIR> 



File (s) 



3,118 AdvException. java 
3, 237 AdvNoSuchBackendExcept ion. java 
CVS 

3,089 IllegalArgument . java 

490 Makefile 
3,175 NoADServiceExcept ion. java 
3,148 ParseErrorException. java 
16,257 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\se 
rvices \advertise\exception\CVS 



12/06/00 
312/06/00 
012/16/99 
^12/16/99 
«12/16/99 
A^12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



349 Entries 
7 6 Repository 
4 6 Root 

84 6 Template 
1,317 bytes 



y Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
' ^ rvices\advertise\query_parser 



^ir:l2/o6/oo 


04 


: 33p 


<DIR> 








:~fl2/06/00 


04 


: 33p 


<DIR> 








:212/06/00 


04 


: 33p 


<DIR> 




CVS 




■£12/07/99 


04 


: 26p 




2,505 


LDAPQueryOps . java 




^'=^12/07/99 


04 


: 2 6p 




747 


Makefile 




12/07/99 


04 


:26p 




3,408 


QueryLeaf Node . j ava 




12/07/99 


04 


:26p 




4,285 


QueryAndNode . j ava 




12/07/99 


04 


:26p 




5,451 


QueryComparatorNode . 


java 


12/07/99 


04 


:26p 




4, 077 


QueryExprNode . j ava 


12/07/99 


04 


:26p 




3, 667 


QueryEqNode . j ava 




12/07/99 


04 


:26p 




3, 095 


QueryGtNode . j ava 




12/07/99 


04 


:26p 




3,101 


QueryGeNode . j ava 




12/07/99 


04 


:26p 




2,252 


Queryldentif ierNode . 


java 


12/07/99 


04 


: 26p 




3,073 


QueryLtNode . j ava 


12/07/99 


04 


:2 6p 




2, 636 


QueryLiteralNode . j ava 


12/07/99 


04 


:26p 




17,430 


QueryLex. java 




12/07/99 


04 


:26p 




3,097 


QueryLeNode . j ava 




12/07/99 


04 


:26p 




3,498 


QueryNotNode . j ava 




12/07/99 


04 


:26p 




3,825 


QueryNeqNode . j ava 




12/07/99 


04 


:26p 




4,373 


QueryOrNode . j ava 




12/07/99 


04 


:26p 




14,678 


QueryParser . j ava 





Page 78 



21 File(s) 



test 

85,198 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\s 
rvices\advertise\query_parser\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/15/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



975 Entries 
79 Repository 
4 6 Root 
846 Template 
1,946 bytes 



Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\s 
rvices\advertise\util 



12/06/00 


04 


: 33p 


0^12/06/00 


04 


: 33p 


'D12/06/00 


04 


: 33p 


^'^^ 12/07/99 


04 


:26p 


W12/07/99 


04 


: 2 6p 


12/07/99 


04 


:26p 


^-12/07/99 


04 


:26p 


17:12/07/99 


04 


:26p 



<DIR> 
<DIR> 
<DIR> 



8 File{s) 



CVS 

3,428 eskill.java 

424 Makefile 
5,560 Multicaster . java 
2,191 Shutdownlntf . java 
6,600 ShutdownCtrl. java 
18,203 bytes 



: Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\s 
;rvices\advertise\util\CVS 



:i2/06/00 
:12/06/00 
'12/16/99 
12/16/99 
12/16/99 
12/16/99 



04: 33p 
04: 33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



257 Entries 
71 Repository 
4 6 Root 

84 6 Template 
1,220 bytes 



Directory of E : \e-speak-src_991217\platform\ES\src\ java\net\espeak\s 
rvices\advertise\ypcoimnon 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 



<DIR> 
<DIR> 



<DIR> 



2,249 AdvDebug . j ava 
6,157 ArraySet . java 
CVS 

689 Makefile 
2,4 65 QueryOps . java 
2,537 YPCompBigDecimal . java 

Page 7 9 







test 


12/07/99 


04 :26p 


2,451 


12/07/99 


04:26p 


9,801 


12/07/99 


04:2 6p 


2, 430 


12/07/99 


04:26p 


2,442 


12/07/99 


04:26p 


2, 566 


12/07/99 


04 :26p 


2,353 


12/07/99 


04 :26p 


2,430 


12/07/99 


04:26p 


2, 418 


12/07/99 


04:25p 


2,439 


12/07/99 


04:26p 


2,504 


12/07/99 


04:26p 


2,087 


12/07/99 


04:26p 


2,745 




20 File(s) 


50,763 



YPCompFloat . j ava 
YPComparator . j ava 
YPCompByte. java 
YPCompDouble. java 
YPComparable . j ava 
YPCompString . j ava 
YPCompShort . j ava 
YPCompLong . j ava 
YPCompInt .java 
YPCompChar . j ava 
YPObjects .java 
YPOperations .java 
bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\ 
rvices\advertise\ypcommon\CVS 



^12/06/00 
^12/06/00 
^12/16/99 
^12/16/99 
^12/16/99 
'12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



890 Entries 
75 Repository 
4 6 Root 
84 6 Template 
1,857 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
.rvices\advertise\ypserver 



:£12/06/00 


04:33p <DIR> 




112/06/00 


04:33p <DIR> 




yi2/07/99 


04:26p 


88,292 


^=^12/07/99 


04:26p 


4,168 


12/07/99 


04:26p 


5,140 


12/07/99 


04:26p 


16,210 


12/06/00 


04:33p <DIR> 


12/07/99 


04:26p 


4,733 


12/07/99 


04:26p 


651 


12/07/99 


04:26p 


4,138 


12/07/99 


04:26p 


5, 346 


12/07/99 


04:26p 


5,438 


12/07/99 


04:26p 


4, 980 


12/07/99 


04:26p 


3,221 


12/07/99 


04:26p 


3,821 


12/07/99 


04:26p 


9, 852 




16 File(s) 


155, 99 



AdvertisingService .java 
BackendLookupResult . j ava 
BackendConnectionlnfo. java 
ConnectionManager . j ava 
CVS 

ExternalEsrl .java 
Makefile 

TimeoutHandler . j ava 
YPGenericTable . j ava 
YPItemsTable . j ava 
YPItem. java 
YPMessage. java 
YPSearchResultsTable . j ava 
YPSearchResult .java 



Directory of E : \e-speak-src__991217\platf orm\ES\src\ java\net\espeak\ 
rvices\advertise\ypserver\CVS 
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test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 728 Entries 

12/16/99 06:21p 75 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,695 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 96 Entries 

12/16/99 06:21p 71 Entries. Log 

,12/16/99 06:20p 56 Repository 

^2/16/99 06:20p 46 Root 

^12/16/99 06:20p 846 Template 

J 7 File(s) 1,115 bytes 

I Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
'rvices\events 



697 compile.bat 
CVS 

5,926 ESCoreDistributor. java 
5, 093 ESManagementDistributor . java 
3,995 ESServiceDistributor. java 
465 Makefile 
510 makefile. release 
9 File(s) 16, 586 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\events\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 335 Entries 

12/16/99 06:21p 63 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,290 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\manageraent 
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^^12/06/00 


04 


: 33p 


<DIR> 


f ,12/06/00 


04 


:33p 


<DIR> 


:r;i2/07/99 


04 


:26p 




;i;i2/o6/oo 


04 


: 33p 


<DIR> 


:£l2/07/99 


04 


:26p 




;£l2/07/99 


04 


:26p 




:=fl2/07/99 


04 


:26p 




^=^12/07/99 


04 


: 26p 




12/07/99 


04 


:26p 





test 



12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


: 26p 




12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 




u4 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 



12 Filefs] 



1,328 compile. bat 
coremanager 
CVS 

logger 

333 Makefile 

759 makefile. release 
policymanager 
processmanager 
servicemanager 
web 
2,420 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices \management \ coremanager 



^012/06/00 


04 


: 33p 


'^^12/06/00 


04 


: 33p 


W12/O7/99 


04 


:26p 


^efl2/07/99 


04 


:26p 


^3l2/07/99 


04 


:26p 


!!^12/07/99 


04 


: 26p 


^^^12/07/99 


04 


:26p 


f. 12/07/99 


04 


:26p 


;!:i2/07/99 


04 


: 26p 


!ifl2/07/99 


04 


:26p 


212/07/99 


04 


:26p 


:i:l2/07/99 


04 


: 26p 


:S12/07/99 


04 


:26p 


'"'12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/15/99 


04 


: OOp 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 



<DIR> 
<DIR> 



<DIR> 



27 File(s) 



27, 653 CoreManager . java 

20,917 CoreManagerMSImpl. java 

12, 661 CoreManagerOS . java 

19,588 CoreManagerMS. java 
705 compile.bat 
7, 599 CoreEventSubscriberliupl .java 
5, 247 CoreEventSubscriber . java 
7,420 CoreManagerTags. java 
6,473 CoreManagerStats . java 
4,484 CoreManagerOSIntf . java 

23,110 CoreManagerOSImpl. java 
CVS 

4,14 8 DbgLog.java 

6,249 EventPublisher , java 

8,116 ExtEventSubscriberlmpl. java 

4, 622 ExtEventSubscriber . j ava 
931 Makefile 
527 makefile. release 

5,151 ServiceDataList. java 

3, 528 Shutdown. java 

5, 112 StateMC. java 

4,434 Staticlnfo. java 
10,091 Stat sReader. java 

3,785 Stat sStore. java 

6,651 UpdateStats. java 
199,202 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
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test 

rvices Xmanagement \coremanager \CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 1,324 Entries 

12/16/99 06:21p 79 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File{s) 2,295 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices Xmanagement \CVS 



12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/16/99 


06:21p 




149 


^.12/16/99 


06:21p 




121 


□12/16/99 


06:21p 




67 


:Dl2/16/99 


06:21p 




46 


:'^n2/16/99 


06:21p 




846 



^ 7 File (3) 1,229 bytes 

I Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
'.rvices Xmanagement \logger 



;M2/06/oo 


04 


:33p 


<DIR> 




:r;i2/o6/oo 


04 


:33p 


<DIR> 




■^12/06/00 


04 


: 33p 


<DIR> 


client 


:S12/06/00 


04 


:33p 


<DIR> 


CVS 


;£l2/07/99 


04 


:26p 




333 Makefil 


;.:a2/06/00 


04 


: 33p 


<DIR> 


manager 


^==■^12/06/00 


04 


: 33p 


<DIR> 


message 


12/06/00 


04 


: 33p 


<DIR> 


service 


12/06/00 


04 


: 33p 


<DIR> 


test 


12/06/00 


04 


:33p 


<DIR> 


types 


12/06/00 


04 


: 33p 


<DIR> 


util 






11 


File (s) 


333 bytes 



Directory of E: Xe-speak-src_991217XplatformXESXsrc\javaXnetXespeakXse 
rvices Xmanagement XloggerXclient 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 4,325 ESLogClient . java 

12/15/99 04:00p 434 Makefile 

5 File(s) 4,759 bytes 
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12/06/00 


04: 


33p 


12/06/00 


04: 


33p 


12/16/99 


06: 


21p 


012/16/99 


06: 


21p 


fll2/16/99 


06: 


21p 


^12/16/99 


06: 


21p 


!«12/16/99 


06: 


21p 






7 



test 

Directory of E:\e-speak-src_991217\platforra\ES\src\java\net\espeak\se 
rvices\manageraent\logger\client\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 101 Entries 

12/16/99 06:21p 81 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,074 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices \management \logger\CVS 

<DIR> 
<DIR> 

48 Entries 

110 Entries. Log 

74 Repository 

46 Root 

84 6 Template 
File(s) 1,124 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
=rvices\management\logger\manager 

^:i2/06/00 04:33p <DIR> 

b:i2/06/00 04:33p <DIR> 

^12/06/00 04:33p <DIR> CVS 

^12/07/99 04:26p 9,765 ESLogServiceServlet . java 

q;i2/07/99 04:26p 69 ESLogServiceManager .properties 

=12/07/99 04:26p 7,964 ESLogServiceManager . j ava 

12/15/99 04:00p 473 Makefile 

7 File(s) 18,271 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices\management\logger\manager\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 237 Entries 

12/16/99 06:21p 82 Repository 

12/16/99 05:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,211 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices \management\logger\message 
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test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04 :33p 
04 :26p 
04 :26p 
5 



<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 

13,666 ESLogMessage . java 
405 Makefile 
14,071 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\logger\message\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



102 Entries 
82 Repository 
4 6 Root 
84 6 Template 
1,076 bytes 



i Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
:rvices\management\logger\ service 



f 12/06/00 04:33p <DIR> 

:i2/06/00 04:33p <DIR> 

^12/06/00 04:33p <DIR> 

.12/07/99 04:26p 

:i2/07/99 04:26p 

:i2/07/99 04:26p 

fl2/07/99 04:26p 

fl2/07/99 04:26p 

fl2/07/99 04:26p 
. j ava 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

17 File(s) 



CVS 

18,657 ESLogFileWriter. java 

3,693 ESLoggerWaitQueue . java 
16,773 ESLogMessageParser . java 

2,281 ESLogServicelntf .esidl 

4,131 ESLogServiceStub. java 

1, 135 ESLogServicelntfMessageRegistry 

2,281 ESLogServicelntf .java 
3,737 ESLogServicelmpl. java 

741 Makefile 
2,727 ServicePackageWhiteBoxTest . j ava 
4,995 TestDenialOf Service. java 
4,380 TestEscapeProcessing. java 
12,892 TestFileWriting. java 
6,023 TestQueueProcessing. java 
84,446 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\logger\service\CVS 



12/06/00 04:33p 
12/06/00 04:33p 
12/16/99 06:21p 



<DIR> 
<DIR> 



839 Entries 
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12/16/99 06:21p 82 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,813 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\se 
rvices\inanagement\logger\test 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 2,058 ESLoggerTest . java 

12/07/99 04:26p 4,297 ESLoggerDef aultTest . j ava 

12/07/99 04:26p 403 Makefile 

6 File(s) 6,758 bytes 

^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvicesXraanageraent \logger\test \CVS 

^"^12/06/00 04:33p <DIR> 

:A^12/06/00 04:33p <DIR> 

:ffl2/16/99 06:21p 163 Entries 

:=:12/16/99 06:21p 79 Repository 

:::i2/16/99 06:21p 46 Root 

;;=12/16/99 06:21p 846 Template 

'i^ 6 File(s) 1,134 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
'-:rvices\management\logger\types 



CVS 

ESLoggableDataltem. j ava 
ESLoggableDataltemList . j ava 
ESLoggableBoolean . j ava 
ESLoggableString . j ava 
ESLoggablelnteger . java 
ESLoggableFloat . j ava 
ESLoggableDate . j ava 
Makefile 
3 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\logger\types\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 



:£l2/06/00 


04:33p 


<DIR> 




■'-"-12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/07/99 


04 :26p 




3, 888 


12/07/99 


04:26p 




4, 928 


12/07/99 


04:26p 




3,485 


12/07/99 


04:26p 




3,481 


12/07/99 


04:26p 




3,531 


12/07/99 


04:26p 




3,529 


12/07/99 


04:26p 




4,459 


12/07/99 


04 :26p 




547 




11 


File (s) 


27, 84 
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12/16/99 
12/16/99 
12/16/99 
12/16/99 



06:21p 
06:21p 
06:21p 
06:21p 
6 



test 
461 
80 
46 
846 



File(s) 



Entries 

Repository 

Root 

Template 



1,433 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices\management\logger\util 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
5 



<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 

2,286 ESLoggableDateFormat . java 
381 Makefile 
2,667 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
irvices \management \logger \ut il \CVS 



^12/06/00 
W12/06/00 
^12/16/99 
^-^12/16/99 
^:=*12/16/99 
^'^12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



110 Entries 
79 Repository 
4 6 Root 

846 Template 
1,081 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
•;jrvices\management\policymanager 



CVS 

f ilingsysteiti 



^12/06/00 


04:33p 


<DIR> 




=^12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/15/99 


04:00p 




1, 397 


12/07/99 


04:26p 




2, 330 


a 

12/07/99 


04:26p 




2,207 


12/07/99 


04:26p 




5,198 


12/07/99 


04:26p 




30, 027 


12/07/99 


04:26p 




2, 145 


ava 








12/07/99 


04 :26p 




3, 828 


12/07/99 


04:26p 




4,792 


12/07/99 


04:26p 




2,819 


12/07/99 


04:26p 




2,708 


12/07/99 


04:26p 




1, 817 


Registry. 


java 







PolicyManagerFactoryInt f . j ava 
PolicyManagerFactorylmpl . j ava 



PolicyLif ecycleEvent . j ava 
PolicyManager Intf . j ava 
PolicyManagerLinkageEvent . j ava 
PolicyManagerLoopException . j ava 
PolicyManagerFactory Intf Message 
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test 


12/07/99 


04:26p 




6, 568 


12/07/99 


04:26p 




2,392 


12/07/99 


04 :26p 




3, 000 


a 

12/07/99 


04:26p 




2,400 


12/07/99 


04:26p 




2, 694 


. java 








12/07/99 


04:26p 




2,247 


java 








12/07/99 


04:26p 




2,225 


va 








12/07/99 


04:26p 




2,219 


12/07/99 


04:26p 




2,549 


. j ava 








12/07/99 


04:26p 




1,394 


y . java 








„,12/07/99 


04:26p 




5,720 


yi2/07/99 


04:26p 




24,384 


;Sl2/07/99 


04:26p 




4,792 


''^12/07/99 


04:26p 




6,112 


!^il2/07/99 


04:26p 




2, 188 


listener, java 






1^12/07/99 


04:26p 




2,069 


■Z'sit . j ava 








^''12/06/00 


04:33p 


<DIR> 





1, 394 PolicyManagerlntfMessageRegistr 



32 File(s) 



2, 0 69 PolicyManagerFactoryShutdownEve 

servlet 
132,221 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
^rvices\management\policymanager\CVS 



:S:12/06/00 


04:33p <DIR> 




'='12/06/00 


04:33p <DIR> 




12/16/99 


06:21p 


1,805 Entries 


12/16/99 


05:21p 


39 Entries. Log 


12/16/99 


06:21p 


81 Repository 


12/16/99 


06:21p 


4 6 Root 


12/16/99 


06:21p 


84 6 Template 




7 File(s) 


2,817 bytes 



Directory of E : \e-speak-src_991217\platform\ES\src\ java\net\espeak\se 
rvices\management\policyinanager\f ilingsystem 



12/06/00 04:33p 

12/06/00 04:33p 

12/07/99 04:26p 

12/07/99 04:26p 
va 

12/06/00 04:33p 



<DIR> 
<DIR> 



<DIR> 



8,047 ChangeList . java 

1, 931 CorruptedPolicyFileException. ja 
CVS 
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12/07/99 04:26p 
12/07/99 04:26p 
12/07/99 04:26p 
12/07/99 04:26p 
java 

12/07/99 04:26p 
properties 
12/15/99 04:00p 
12/07/99 04:26p 

12 File(s; 



test 

13,747 FileFormatter . java 

9,032 FileLoader. java 

5,168 FileUtil. java 

17, 791 FilingSystemPersistencyManager 

33 FilingSystemPersistencyManager 

590 Makefile 

11,933 PolicyManagerFile. java 
68,272 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\s 
rvices\management\policyitianager\f ilingsystem\CVS 



12/06/00 
12/06/00 
12/16/99 
112/16/99 
112/16/99 
112/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



536 Entries 
94 Repository 
46 Root 

84 6 Template 
1,522 bytes 



=^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\s 
^rvices\management\policymanager\servlet 



^ 12/06/00 

:::i2/o6/oo 

^fl2/06/00 
rfl2/15/99 
fl2/07/99 



04:33p 
04:33p 
04:33p 
04:00p 
04:26p 
5 



<DIR> 
<DIR> 
<DIR> 



File (s' 



CVS 

424 Makefile 
16,601 PolicyManagerServlet . java 
17, 025 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\si 
rvices\management\policymanager\servlet\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 

6 File(s) 



<DIR> 
<DIR> 



110 Entries 
8 9 Repository 
4 6 Root 

846 Template 
1,091 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\sf 
rvices\manageraent\processmanager 



12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
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test 



12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/07/99 


04 


:26p 




349 Makefile 


12/05/00 


r\ A 

04 


: 33p 


<DIR> 


service 


iz/ uo/ UU 




- 0 jp 


<DIR> 


shell 


12/06/00 


04 


: 33p 


<DIR> 


statemonitor 


12/06/00 


04 


: 33p 


<DIR> 


test 


12/06/00 


04 


: 33p 


<DIR> 


util 


12/06/00 


04 


: 33p 


<DIR> 


web 






10 


File (s) 


349 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\processmanager\CVS 



12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/16/99 


06 :21p 




48 


12/16/99 


06:21p 




95 


O12/I6/99 


06:21p 




82 


^012/16/99 


06:21p 




46 


■=^12/16/99 


06:21p 




846 



7 File(s) 



Entries 
Entries . Log 
Repository 
Root 

Template 
1,117 bytes 



' Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
;;rvices\raanagement\processmanager\service 



12/06/00 
'12/06/00 
fl2/06/00 
fl2/07/99 
fl2/07/99 
fl2/07/99 
^12/07/99 
12/07/99 
12/07/99 
12/07/99 
eRegistry , 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
java 
04:26p 
04:26p 
12 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

652 Makefile 
2, 226 ProcessManagerException. java 
4,494 ProcessManager . java 
5, 155 ProcessManagerServicelntf . esidl 
8, 380 ProcessManagerServiceStub. java 
1, 923 ProcessManagerException. esidl 
1, 393 ProcessManagerServicelntfMessag 

5, 155 ProcessManagerServicelntf . java 
10, 069 ProcessManagerService. java 
39,447 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\processmanager\service\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 



<DIR> 
<DIR> 



582 Entries 
90 Repository 
4 6 Root 
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12/16/99 06:21p 

6 File(s) 



test 

84 6 Template 
1,564 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\ 
rvices\inanagement\processraanager\shell 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
7 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

427 Makefile 
11,963 PMShellService. java 
24,700 PMShellConsole. java 

4,103 PMShell.java 

41,193 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
^rvices\management\processmanager\shell\CVS 



;Dl2/06/00 
■^2/06/00 
W12/16/99 
W12/I6/99 
1-^12/16/99 
:n2/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



209 Entries 
88 Repository 
4 6 Root 

84 6 Template 
1,189 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
r^rvices\management\processmanager\statemonitor 



3.2/06/00 
fi2/06/00 
42/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04: 33p 
04:26p 
04:33p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

15 File(s) 



<DIR> 
<DIR> 

<DIR> 



4,182 CoreConnectionMonitor . java 
CVS 

3,129 ESJoblntf . java 
1,8 68 ES Job. java 
3,731 In JVM Job. java 

641 Makefile 
4,007 MonitorlniFile. java 
5,260 Process Job. java 
3,947 StateMonitorlntf . java 
1,7 94 StateMonitorExcept ion. java 
4,67 9 StateMonitorConfig. java 
3,468 StateMonitor. java 
5,362 TaskErrStreamMonitor . java 
42,068 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ 
rvices\management\processmanager\statemonitor\CVS 
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test 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 664 Entries 

12/16/99 06:21p 95 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,651 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\se 
rvices\management\processmanager\test 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 378 Makefile 

12/07/99 04:26p 176 TEST.ESH 

312/07/99 04:26p 2,416 TestTask. java 

y 6 File(s) 2,970 bytes 

« Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
^frvices\management\processinanager\test\CVS 

=12/06/00 04:33p <DIR> 
^12/06/00 04:33p <DIR> 

12/16/99 06:21p 143 Entries 

r:i2/16/99 06:21p 87 Repository 

!;i2/16/99 06:21p 46 Root 

^2/16/99 06:21p 846 Template 

^ 6 File(s) 1,122 bytes 

- Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\processmanager\util 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:26p 3,136 ClientHelper . java 

12/07/99 04:26p 3,815 CommandLine . java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 3,272 InJVMRunner . java 

12/07/99 04:26p 2,979 lOPipe.java 

12/07/99 04:26p 493 Makefile 

12/07/99 04:26p 3,715 SimpleLoader . java 

9 File(s) 17,410 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\manageraent\processmanager\util\CVS 
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12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 



<DIR> 
<DIR> 



6 File(s) 



test 



310 Entries 
87 Repository 
4 6 Root 

84 6 Template 
1,289 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\raanageinent\processmanager\web 



12/06/00 
12/06/00 
12/06/00 
12/15/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:00p 
04:26p 
04:26p 
6 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

447 Makefile 
12,009 PMShellServlet. java 
129 servlet .properties 
12,585 bytes 



^ Directory of E:\e-speak-src_991217\platforra\ES\src\java\net\espeak\se 
^:rvices\management\processmanager\web\CVS 



:12/06/00 
'12/06/00 
'^12/16/99 
12/16/99 
'12/16/99 
fl2/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



159 Entries 
8 6 Repository 
4 6 Root 

84 6 Template 
1,137 bytes 



^' Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
=rvices\management\servicemanager 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
ava 

12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 



<DIR> 
<DIR> 
<DIR> 



CVS 

848 Makefile 
9,820 ServiceManager . java 
3 , 322 ServicelnstanceManager . j ava 
9,858 ServiceEventHandler . j ava 
2, 093 ServicelnstanceManagerFailure. j 

2, 142 ServiceControllerFailure. java 

2, 082 ServiceEventHandlerFailure. java 

7,351 ServiceController . java 

2,289 ServiceManagerlntf . esidl 

5,091 ServiceManagerStub. java 

1,273 ServiceManagerlntf MessageRegist 

Page 93 



test 

ry. java 

12/07/99 04:26p 2,318 ServiceManagerlntf . java 

12/07/99 04:26p 2,714 ServiceManagerlmpl . j ava 

12/06/00 04:33p <DIR> ui 

17 File(s) 51,201 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\se 
rvices\management\servicemanager\CVS 

12/06/00 04:33p <DIR> 

12/05/00 04:33p <DIR> 

12/16/99 06:21p 809 Entries 

12/16/99 06:21p 12 Entries. Log 

12/16/99 06:21p 82 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

1 File{s) 1,7 95 bytes 

^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
'*Jrvices\management\servicemanager\ui 

^12/06/00 04:33p <DIR> 

f 12/06/00 04:33p <DIR> 

ni2/07/99 04:26p 1,888 ChangeStateFailed. java 

^12/06/00 04:33p <DIR> CVS 

.^12/15/99 04:00p 842 Makefile 

1=12/07/99 04:26p 2,036 ModelExcept ion. java 

;^12/07/99 04:26p 6,867 ServiceManagerUI . java 

:il2/07/99 04:26p 3, 470 ServiceManagerTableModel . j ava 

;i2/07/99 04:26p 15,099 ServiceManagerServlet . java 

::12/07/99 04:26p 21, 904 ServiceManagerModel . java 

='12/07/99 04:26p 193 servlet .properties 

12/07/99 04:26p 8,894 UiServiceManagerAdapter . j ava 

12/07/99 04:26p 6,577 UiServiceManager . j ava 

13 File(s) 67,770 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\servicemanager\ui\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 589 Entries 

12/16/99 06:21p 85 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,566 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
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rvices \manageinent \web 



test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> servlets 

4 File(s) 0 bytes 

Directory of E: \e-spealc-src_991217\platform\ES\src\java\net\espeak\se 
rvices \management\web\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 3 Entries 

12/16/99 06:21p 18 Entries. Log 

12/16/99 06:21p 71 Repository 

12/16/99 06:21p 46 Root 

il2/16/99 06:21p 846 Template 

7 File{s) 984 bytes 

i Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
f rvices \management\web\servlets 

U2/06/00 04:33p <DIR> 
^2/06/00 04:33p <DIR> 

.12/07/99 04:26p 7,457 CoreServlet . j ava 

:l2/06/00 04:33p <DIR> CVS 

fl2/15/99 04:00p 461 Makefile 

f 12/07/99 04:26p 10,758 Management Servlet . j ava 

^ 6 File(s) 18,676 bytes 

' Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\se 
rvices \management\web\servlets\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 160 Entries 

12/16/99 06:21p 80 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,132 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\tunnel 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:26p 6,943 AbstractSocket . j ava 

Page 95 







test 


12/07/99 


04:26p 


1, 894 


12/07/99 


04:26p 


2,219 


12/07/99 


04:26p 


1,781 


12/07/99 


04:26p 


2,525 


12/07/99 


04:26p 


2,428 


12/07/99 


04:26p 


700 


12/07/99 


04:26p 


2,227 


12/06/00 


04:33p <DIR> 




12/07/99 


04:26p 


6,227 


12/07/99 


04:26p 


3,218 


12/07/99 


04:26p 


2, 984 


12/07/99 


04:26p 


1,777 


12/07/99 


04:26p 


2,203 


12/07/99 


04:26p 


4,777 


12/07/99 


04:26p 


245 


12/07/99 


04:26p 


7,531 


12/07/99 


04:26p 


3, 970 


□12/07/99 


04:26p 


5,860 


012/07/99 


04:26p 


1,861 


^Jl2/07/99 


04:26p 


3,210 


^^12/07/99 


04:26p 


3,413 


^^12/07/99 


04:26p 


2,802 


3l2/07/99 


04:26p 


1, 114 


?:12/07/99 


04:26p 


0 


^^^12/07/99 


04:26p 


518 


' 12/07/99 


04:26p 


1,724 


f:i2/07/99 


04:26p 


2,789 


ifl2/07/99 


04:26p 


2, 195 


£12/07/99 


04:26p 


1, 674 


il2/07/99 


04:26p 


1, 686 


il2/07/99 


04:26p 


1,788 


=12/07/99 


04:26p 


252 


12/07/99 


04:26p 


4, 534 


12/07/99 


04:26p 


2, 782 


12/07/99 


04:26p 


6, 878 


12/07/99 


04:26p 


7,590 




39 File(s) 


106, 31i 



CVS 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\ tunnel \CVS 



12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:21p 


2,001 Entries 


12/16/99 


06:21p 


63 Repository 


12/16/99 


06:21p 


4 6 Root 


12/16/99 


06:21p 


84 6 Template 




6 File{s) 


2, 956 bytes 
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test 



il 






12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


;26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/05/00 


04 


:33p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/06/00 


04 


: 33p 


□12/07/99 


04 


:26p 


^012/07/99 


04 


: 26p 


'M12/07/99 


04 


: 26p 


W12/07/99 


04 


:26p 


W12/07/99 


04 


:26p 


□12/07/99 


04 


:26p 


^^=^12/07/99 


04 


:26p 


^1=112/07/99 


04 


:26p 


12/07/99 


04 


:26p 


^■=-^2/07/99 


04 


:26p 


^"Ul2/07/99 


04 


: 26p 


-12/07/99 


04 


:26p 


^3312/07/99 


04 


: 2 6p 


yi2/07/99 


04 


: 26p 


^=^12/06/00 


04 


: 33p 


12/15/99 


04 


: OOp 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/06/00 


04 


:33p 



<DIR> 
<DIR> 



<DIR> 



<DIR> 



<DIR> 
<DIR> 



<DIR> 



6,191 Assert. java 
2,023 Codecoverage. java 
2,289 CoverageThread. java 
CVS 

3,729 ErrorMsg. java 
15,301 ESAbstractWriter. java 

9,088 ESArray.java 

2,605 ESContainer . java 
26,220 ESDebug.java 

5,855 ESFileWriter. java 
esidl 

6,271 ESList.java 

3,817 ESLogSt ream. java 

2,997 ESMapNode. java 
16,204 ESMap.java 

2,747 ESPrintWriter. java 

4, 619 ESSet . java 

6,346 ESString. java 
10,178 ESStrings . java 
17,634 ESText.java 
14,600 ESTracer. java 

2,099 ExternalLogger. java 

6,221 FileServerServlet. java 

7,029 GenericListenerList . java 
19,890 IniFile.java 
io 

1,400 Makefile 

misc 

4,161 NullPrintStream. java 

4,350 Poll. java 
50,112 SysLoader . java 

6,639 TasklnJVM. java 

3,64 6 TaskLoader . java 

8,240 TaskNew JVM. java 

6,598 TaskRemote . java 

7,785 TaskReader . java 

4,939 TaskServer . java 

3,170 TaskWatcher . java 
32, 665 Task. java 

3,430 TestHelper. java 

6,416 Trace. java 
ts 
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12/06/00 04:33p 
12/07/99 04:26p 

46 File(s: 



test 

<DIR> tsutil 

6,296 UniquelD. java 
343,800 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\ut 
il\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 
7 



<DIR> 
<DIR> 



File(s) 



1,957 
69 
52 
46 
846 
2, 970 



Entries 
Entries .Log 
Repository 
Root 

Template 
bytes 



□ ilXesidl 








^^12/06/00 


04:33p 


<DIR> 




W 12/06/00 


04:33p 


<DIR> 




W 12/07/99 


04:26p 




11, 106 


O12/06/00 


04:33p 


<DIR> 




^'='"12/07/99 


04:26p 




32,286 


^12/07/99 


04:26p 




13,857 


12/07/99 


04:26p 




3, 997 


^:^:i2/07/99 


04:26p 




2,391 


^^12/07/99 


04:26p 




593 


yi2/07/99 


04:26p 




20, 659 


^i:^12/07/99 


04:26p 




3,320 


^12/07/99 


04:26p 




7,153 


■=^12/07/99 


04:26p 




18, 662 


12/07/99 


04:26p 




18,593 


12/07/99 


04:26p 




14, 618 



15 File(s) 



CVS 



147,235 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
Ll\esidl\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 

6 File(s) 



<DIR> 
<DIR> 



659 Entries 
58 Repository 
46 Root 

84 6 Template 
1,609 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
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il\io 



test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
10 



<DIR> 
<DIR> 
<DIR> 



File (s; 



CVS 

5,283 FileOutputStream. java 

4,154 LogContext . java 

8,302 LogEnv.java 

7,550 Logger. java 

4,571 LogOutput St ream. java 

455 Makefile 
3,029 NullOutput Stream. java 
33,344 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
il\io\CVS 



il2/06/00 
^12/06/00 
il2/16/99 
^12/16/99 
^12/16/99 
^12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



369 Entries 
55 Repository 
4 6 Root 

846 Template 
1,316 bytes 



ir!il\misc 








S12/O6/OO 


04 


: 33p 


<DIR> 


:iii2/o6/oo 


04 


: 33p 


<DIR> 


yi2/07/99 


04 


:26p 




^"^12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


: 26p 




12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




12/07/99 


04 


: 26p 




12/07/99 


04 


:26p 








10 


File (s) 



2,422 Array. java 
12,4 60 ByteArray . java 

4,536 ByteBuf fer . java 
10,566 Cons. java 
CVS 

429 Makefile 
5,387 Queue. java 
2,042 Testable. java 
37,842 bytes 

Directory of E : \e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
il\misc\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 



<DIR> 
<DIR> 



341 Entries 
57 Repository 
46 Root 
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12/16/99 06:21p 

6 File{s; 



test 

84 6 Template 
1,290 bytes 



Directory of E: \e-speak-src_991217\platforin\ES\src\ java\net\espeak\ut 
il\ts 



12/06/00 
12/05/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
^12/07/99 
^12/07/99 
^12/07/99 
:i2/07/99 
^12/07/99 
^12/07/99 
;.12/07/99 
^12/07/99 
12/07/99 
:i2/07/99 
:12/07/99 
:i2/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
23 



<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 

731 Makefile 

3,820 PrettyPrintManager . java 
4 9,630 TSAtomic. java 

5,305 TSBoolean. java 

2,867 TSDatePP. java 

2,764 TSDefaultFactory. java 

3,105 TSFactory. java 
10,751 TSLexical. java 
18,143 TSList.java 

2,829 TSMapEnumeration. java 
28,181 TSMap.java 

3,044 TSObservable. java 
22,612 TSParser. java 

2,237 TSParseException. java 

2,488 TSPrettyPrinter. java 

6,701 TSTest.java 
30,139 TSUtils.java 

8,179 TSValue.java 

3,771 TSVisitor. java 

2,520 TypeErrorExcept ion. java 
209,817 bytes 



' Directory of E:\e-speak-src_991217\platforin\ES\src\java\net\espeak\ut 
il\ts\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 



<DIR> 
<DIR> 



1,048 
55 
46 
846 



6 File(s) 



Entries 

Repository 

Root 

Template 



1, 995 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ut 
ilXtsutil 



12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 



CVS 
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test 




12/07/99 


04 


:26p 


4, 605 


List . java 


12/07/99 


04 


:26p 


498 


Makefile 


12/07/99 


04 


: 26p 


4, 889 


Map . j ava 


12/07/99 


04 


:26p 


11,159 


Syn. java 


12/07/99 


04 


: 2 6p 


2,545 


TSBinary . java 


12/07/99 


04 


:26p 


2,335 


TSBoolean . j ava 


12/07/99 


04 


: 26p 


2,342 


TSInteger . java 


12/07/99 


04 


:26p 


2,310 


TSNumber. java 


12/07/99 


04 


:26p 


2,225 


TSString. java 


12/07/99 


04 


: 26p 


2,165 


TSTag. java 


12/07/99 


04 


:26p 


2,426 


TSToken. java 






14 File(s) 


37,49 


9 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
il\tsutil\CVS 



„.12/06/00 04:33p <DIR> 

^?12/06/00 04:33p <DIR> 

:yi2/16/99 06:21p 

,112/16/99 06:21p 

:^12/16/99 06:21p 

ii:12/16/99 06:21p 
li ^ File(s) 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\we 



;\baccess 












!ifl2/06/00 


04 


: 33p 


<DIR> 






;Sl2/06/00 


04 


:33p 


<DIR> 






;t:i2/o6/oo 


04 


: 33p 


<DIR> 




conf 


:il2/07/99 


04 


: 26p 




3,264 


Converter Intf . j ava 


'=12/07/99 


04 


:26p 




2,913 


Converterinf o .java 


12/06/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




3,765 


DispatchTable . j ava 


12/07/99 


04 


:26p 




15,409 


ESConverter . j ava 


12/07/99 


04 


:26p 




10, 988 


ESFormMapper . j ava 


12/07/99 


04 


:26p 




11,250 


ESMapper . j ava 


12/07/99 


04 


:26p 




2, 067 


ESMessageXml . j ava 


12/07/99 


04 


:26p 




5,440 


ESProcessor . java 


12/07/99 


04 


: 26p 




4,423 


FormGenericMapper . j ava 


12/07/99 


04 


:26p 




4,589 


FormLoginMapper . j ava 


12/07/99 


04 


:26p 




3,703 


Gener icMapper . j ava 


12/07/99 


04 


: 26p 




6,801 


GenericConverter . j ava 


12/06/00 


04 


:33p 


<DIR> 




htdocs 


12/07/99 


04 


:26p 




4,429 


Mailbox. java 


12/15/99 


04 


: OOp 




1,385 


Makefile 


12/07/99 


04 


:26p 




634 


makefile . release 


12/07/99 


04 


: 26p 




3, 165 


Mapperinf o . j ava 



532 Entries 
59 Repository 
4 6 Root 

84 6 Template 
1,483 bytes 
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test 


12/07/99 


04:26p 


2,573 


12/07/99 


04:26p 


2,040 


12/07/99 


04:26p 


2,716 


12/07/99 


04:26p 


3,667 


12/07/99 


04:26p 


2,257 


12/07/99 


04:26p 


2,288 


12/07/99 


04:26p 


2,265 


12/07/99 


04:26p 


2,267 


12/07/99 


04:26p 


2,241 


12/07/99 


04:26p 


4,866 


12/07/99 


04:26p 


4,779 


12/07/99 


04:26p 


3,155 


12/07/99 


04:26p 


7,992 


12/07/99 


04:26p 


16,885 


12/07/99 


04:26p 


5, 929 


12/07/99 


04:26p 


2, 971 


12/07/99 


04:26p 


3,732 


□12/07/99 


04:26p 


5,255 


fll2/07/99 


04:26p 


3,455 


''^*12/07/99 


04:26p 


7,845 


W12/07/99 


04:26p 


6,889 


W12/07/99 


04:26p 


2, 663 


□12/07/99 


04:26p 


2,472 


^=^12/07/99 


04:26p 


6, 942 


^^12/07/99 


04:26p 


9,263 




46 File(s) 


201, 632 



If Directory of 
iaccessXconf 



E: \e-speak-src_991217\platforin\ES\src\java\net\espeak\we 



W12/06/00 


04 


:33p 


<DIR> 




^^12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/07/99 


04 


:26p 




27,318 httpd.conf 


12/06/00 


04 


:33p 


<DIR> 


j serv 






5 


File (s) 


27,318 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\we 
baccess\conf \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 

7 File(s) 



<DIR> 
<DIR> 



50 Entries 
15 Entries. Log 
62 Repository 
46 Root 
846 Template 
1, 019 bytes 
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test 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\we 
baccess\conf \ j serv 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 6,559 1 serv. conr 

12/07/99 04:26p 12,790 j serv. properties 

12/07/99 04:26p 6,496 zone . properties 

6 File(s) 25,845 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\j ava\net \espeak\we 
baccessXconf \ j serv\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

^12/16/99 06:21p 155 Entries 

^2/16/99 06:21p 68 Repository 

^12/16/99 06:21p 46 Root 

}l2/16/99 06:21p 846 Template 

I 6 File(s) 1,115 bytes 



^='baccess\CVS 




i:'l2/06/00 


04: 


33p 


'!:12/06/00 


04: 


33p 


:s:i2/i6/99 


06: 


21p 


:ifl2/16/99 


06: 


21p 


:S12/16/99 


06: 


21p 


^=•12/16/99 


06: 


21p 


12/16/99 


06: 


21p 



<DIR> 
<DIR> 

2^,218 Entries 

30 Entries. Log 

57 Repository 

4 6 Root 

84 6 Template 
7 File(s) 3,197 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\we 
baccess\htdocs 



12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


: 26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


: 26p 





699 ask-lu-vocab.html 

7 03 as k-reg-vocab . html 

665 book-buying.html 

509 button-back-to-register.gif 
CVS 

11,638 ESPEAK.jpg 

886 green-ball.gif 

1,4 54 index.html 
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test 



12/07/99 


04 


: 26p 


1,107 login-reply.html 


12/07/99 


04 


: 26p 


1,102 logo.gif 


12/07/99 


04 


:26p 


1,265 lookup-form. html 


12/07/99 


04 


:26p 


691,318 maylOic.bmp 


12/07/99 


A A 

04 


: 26p 


41,279 maylOicopg 


12/07/99 


04 


:26p 


1, 522 register-form. html 


12/06/00 


04 


:33p <DIR> 


servlets 


12/07/99 


04 


:26p 


148, 992 web-espeak__slides .ppt 


12/07/99 


04 


:26p 


5,34 6 welcomenew, gif 






19 File(s) 


908,485 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\we 
baccess\htdocs\CVS 



12/06/00 


04:33p 


<DIR> 






12/06/00 


04:33p 


<DIR> 






12/16/99 


06:22p 




785 


Entries 


ai2/16/99 


06:22p 




18 


Entries .Log 


^012/16/99 


06:21p 




64 


Repository 


^'^12/16/99 


06:21p 




46 


Root 


W12/I6/99 


06:21p 




846 


Template 



7 File(s) 1,759 bytes 



i!^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\we 
^^"'baccess\htdocs\ servlets 



i:':i2/o6/oo 


04 


: 33p 


<DIR> 






^if 12/06/00 


04 


: 33p 


<DIR> 






y 12/07/99 


04 


: 26p 




20, 614 


BookBroker. java 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


^r:12/07/99 


04 


:26p 




7, 045 


Forms . j ava 


^=^2/07/99 


04 


:26p 




6,645 


HTML2XML. java 


12/07/99 


04 


:26p 




4,089 


IsItWorking. java 


12/15/99 


04 


:00p 




575 


Makefile 


12/07/99 


04 


: 26p 




40 


proxy . cfg 


12/07/99 


04 


:26p 




10, 518 


ProxyBarnes . j ava 


12/07/99 


04 


:26p 




12,489 


ProxyFatBrain . j ava 


12/07/99 


04 


:26p 




3, 578 


Proxyinf 0 . j ava 


12/07/99 


04 


:26p 




5, 467 


ShowRegistrationForm 


12/07/99 


04 


:26p 




2,224 


XMLDocTags . j ava 






14 


File (s) 


73,284 


bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\we 
baccess\htdocs\servlets\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:22p 569 Entries 
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12/15/99 
12/16/99 
12/16/99 



06:22p 
06:22p 
06:22p 

6 File(s) 



test 

73 Repository 
46 Root 
846 Template 
1,534 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\perl 



12/06/00 
12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
4 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 
plesi 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\perl\CVS 



12/06/00 
12/06/00 
112/16/99 
a2/16/99 
^2/16/99 
^12/16/99 
^12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 

7 File{s) 



<DIR> 
<DIR> 



3 Entries 
15 Entries. Log 
36 Repository 
4 6 Root 
846 Template 
946 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\perl\plesi 



:r;i2/o6/oo 


04: 


33p 


^jfl2/06/00 


04: 


33p 


yi2/07/99 


04: 


26p 


:£12/07/99 


04: 


26p 


isfl2/07/99 


04: 


26p 


■-^12/06/00 


04: 


33p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 






17 


Directory of 


E: 


12/06/00 


04: 


33p 



<DIR> 
<DIR> 



<DIR> 



9,832 ABI.pm 

10,309 abi2c.pl 

2,220 abi2txt.pl 
CVS 

18,584 ESLib.pm 

13,760 ESReader.pm 

8,467 ESUtil.pm 

7,139 ESWriter.pm 

7,051 logexpand.pl 

15,7 99 README.txt 

2,636 rtc.pl 

4,849 rts.pl 

2,019 sigbytes.pl 

2,701 tc.pl 

3,179 ts.pl 
108,545 bytes 



<DIR> 
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12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 



File (s) 



test 

639 Entries 
42 Repository 
46 Root 
846 Template 
1,573 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
4 File(s) 



CVS 
pyesi 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python\CVS 



h2/06/00 
^2/06/00 
^12/16/99 
^12/16/99 
^12/16/99 
^12/16/99 
'12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 

7 File(s) 



<DIR> 
<DIR> 



3 Entries 
15 Entries. Log 
38 Repository 
46 Root 
84 6 Template 
948 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi 



;12/06/00 04:33p <DIR> 

::i2/06/00 04:33p <DIR> 

::i2/06/00 04:33p <DIR> 

=12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:26p 

12/06/00 04:33p <DIR> 

12/07/99 04:26p 

9 File(s) 



abi 
CVS 
io 
net 

25,590 README.txt 
Util 

0 init .py 

25,590 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\python\pyesi\abi 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 



04 : 33p 
04:33p 
04 :26p 
04:26p 
04:26p 
04:33p 
04:26p 



<DIR> 
<DIR> 



<DIR> 



17,585 abi.py 

2,480 abi2txt.py 
48,218 abiobj.py 
CVS 

18,088 eslib.py 



Page 106 



test 



12/07/99 


04:26p 


6,762 esobj.py 


12/07/99 


04:26p 


2,476 esutil.py 


12/07/99 


04:26p 


9,925 es_input stream. py 


12/07/99 


04:26p 


11,082 es_output stream. py 


12/07/99 


04:26p 


10,554 genabi.py 


12/07/99 


04:26p 


7, 026 genobj .py 


12/06/00 


04:33p <DIR> 


msg 


12/07/99 


04:26p 


5,049 rtc.py 


12/07/99 


04 : 26p 


10,667 rts.py 


12/07/99 


04:26p 


2,168 sigbytes.py 


12/07/99 


04:26p 


5,455 tc.py 


12/07/99 


04:26p 


7,777 ts.py 


12/07/99 


04:26p 


0 init .py 




20 File{s) 


165,312 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\abi\C 

.,VS 



012/06/00 


04 : 


33p <DIR> 




'^:12/06/00 


04: 


33p <DIR> 




=^12/15/99 


06: 


22p 


744 Entries 


^12/16/99 


06: 


22p 


13 Entries. Log 


^12/16/99 


06: 


22p 


48 Repository 


!:i2/16/99 


06: 


22p 


4 6 Root 


■^12/16/99 


06: 


22p 


846 Template 






7 File(s) 


1,697 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi\abi\m 

;|sg 



5:12/06/00 


04 


: 33p 


<DIR> 








=='12/06/00 


04 


: 33p 


<DIR> 








12/06/00 


04 


: 33p 


<DIR> 




CVS 




12/07/99 


04 


:26p 




8 


msgOOOl. 


ser 


12/07/99 


04 


: 2 6p 




117 


msg0002 . 


ser 


12/07/99 


04 


:2 6p 




154 


msg0003. 


ser 


12/07/99 


04 


:26p 




53 


msg0004 . 


ser 


12/07/99 


04 


: 26p 




159 


msg0005. 


ser 


12/07/99 


04 


:26p 




53 


msgOOOe. 


ser 


12/07/99 


04 


:26p 




194 


msg0007. 


ser 


12/07/99 


04 


:26p 




53 


msgOOOS . 


ser 


12/07/99 


04 


: 26p 




151 


msg0009. 


ser 


12/07/99 


04 


:26p 




53 


msgOOlO. 


ser 


12/07/99 


04 


:26p 




353 


msgOOll . 


ser 


12/07/99 


04 


:26p 




53 


msg0012 . 


ser 


12/07/99 


04 


:26p 




275 


msg0013 . 


ser 


12/07/99 


04 


:26p 




53 


msg0014 . 


ser 


12/07/99 


04 


:26p 




8 


msgOOlS , 


ser 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
.12/07/99 
h2/07/99 
U2/07/99 
n2/07/99 
tl2/07/99 
fl2/07/99 
:^12/07/99 
:i2/07/99 
'12/07/99 
.12/07/99 
=12/07/99 
'12/07/99 
il2/07/99 
fl2/07/99 
J12/07/99 
^12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:25p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

55 File(s; 



test 

117 msgOOie.ser 
154 msg0017.ser 
53 msgOOlS.ser 
159 msg0019.ser 

53 nisg0020.ser 
136 msg0021.ser 

54 msg0022.ser 
92 msg0023.ser 
54 msg0024.ser 

157 msg0025.ser 

53 msg0026.ser 

91 msg0027.ser 
57 msg0028.ser 
71 msg0029.ser 

54 insg0030.ser 
71 msgOOSl.ser 
54 msg0032.ser 
86 msg0033.ser 
54 msg0034 . ser 

156 msg0035.ser 
54 iiisg0036.ser 

92 msg0037.ser 
54 msg0038.ser 

157 msg0039.ser 

53 msg0040.ser 
91 msg0041.ser 
57 msg0042.ser 
71 msg0043.ser 

54 msg0044.ser 
71 msg0045.ser 
54 msg0046.ser 
86 msg0047.ser 
54 insg0048.ser 

121 msg0049.ser 
145 msg0050.ser 
75 insg0051.ser 

93 msg0052.ser 
4,895 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\python\pyesi\abi\m 
sg\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:22p 

12/16/99 06:22p 

12/16/99 06:22p 

12/16/99 06:22p 



<DIR> 
<DIR> 



2,499 Entries 
52 Repository 
4 6 Root 
84 6 Template 
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6 File(s) 



test 
3,443 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\python\pyesi\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:22p 98 Entries 

12/16/99 06:22p 52 Entries. Log 

12/16/99 06:22p 44 Repository 

12/16/99 06:22p 46 Root 

12/16/99 06:22p 846 Template 

7 File(s) 1,086 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\io 



12/06/00 


04:33p 


<DIR> 




,12/06/00 


04:33p 


<DIR> 




^12/07/99 


04:26p 




6,758 


:Ol2/07/99 


04:26p 




3,326 


.^n2/07/99 


04:26p 




2, 691 


'^U2/07/99 


04:26p 




2,762 


^i^l2/06/00 


04:33p 


<DIR> 




:=:^12/07/99 


04:26p 




7,225 


:::i2/07/99 


04:26p 




9, 129 


^^12/07/99 


04:26p 




5,792 


' 12/07/99 


04:26p 




2, 668 


:ra2/07/99 


04:26p 




4,906 


:iil2/07/99 


04:26p 




3,843 


:"a2/07/99 


04:26p 




3, 453 


;£l2/07/99 


04:26p 




3, 695 


;sfl2/07/99 


04:26p 




2, 704 


'=="12/07/99 


04:26p 




2, 678 


12/07/99 


04:26p 




6,055 


12/07/99 


04:26p 




4, 126 


12/07/99 


04:26p 




4,358 


12/07/99 


04:26p 




3, 948 


12/07/99 


04:26p 




4, 315 


12/07/99 


04:26p 




4,087 


12/07/99 


04:26p 




6,477 


12/07/99 


04:26p 




3, 535 


12/07/99 


04:26p 




3,579 


12/07/99 


04:26p 




4,494 


12/07/99 


04:26p 




4,713 


12/07/99 


04:26p 




4,239 


12/07/99 


04:26p 




3,466 


12/07/99 


04:26p 




3, 646 


12/07/99 


04:26p 




8, 115 


12/07/99 


04:26p 




0 



CVS 



init .py 
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33 File(s) 



test 
130,783 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\python\pyesi\io\CV 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s) 



1,724 Entries 
47 Repository 
4 6 Root 
84 6 Template 
2,663 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\python\pyesi\net 



14,7 63 client_socket .py 
CVS 

9,316 http_client_stream.py 
5,148 server_socket .py 
4,848 simple_server .py 
3,626 simple_handler .py 
3,266 socket_output_stream.py 
3,294 socket_input_streain.py 
4,710 threaded_server .py 
2,562 threaded_handler.py 

0 init .py 

51,533 bytes 

5 Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi\net\C 

-vs 



12/06/00 


04:33p 


<DIR> 


_ 12/06/00 


04:33p 


<DIR> 


312/07/99 


04:26p 




D12/06/00 


04:33p 


<DIR> 


"^12/07/99 


04:26p 




^=12/07/99 


04:26p 




S12/07/99 


04:26p 




=^12/07/99 


04:26p 




:^12/07/99 


04:26p 




"12/07/99 


04:26p 




'.12/07/99 


04:26p 




f:i2/07/99 


04:26p 




Jfl2/07/99 


04:26p 






13 


File (s) 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:22p 

12/16/99 06:22p 

12/16/99 05:22p 

12/16/99 06:22p 

6 File(s) 



<DIR> 
<DIR> 



552 Entries 
48 Repository 
4 6 Root 

846 Template 
1,492 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi\util 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04 : 33p 
04:33p 
04 -.26? 
04:26p 



<DIR> 
<DIR> 
<DIR> 



CVS 

10,033 f ile_observer . py 
16,433 f ile_queue.py 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
10 



File (s) 



test 

8,638 log.py 

3,565 thread_pool . py 

3,039 timestamp.py 

6,417 url.py 

0 init .py 

48,125 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\python\pyesi\util\ 
CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s) 



340 Entries 
4 9 Repository 
4 6 Root 

84 6 Template 
1,281 bytes 



P Directory of E:\e-speak-src_991217\platform\ES\tutorial 



1^^12/06/00 
W12/O6/OO 
■312/06/00 
■:^12/07/99 
^"^^12/06/00 
" 12/06/00 



04:33p 
04:33p 
04:33p 
04:26p 
04:33p 
04:33p 
6 



<DIR> 
<DIR> 
<DIR> 

<DIR> 
<DIR> 



File (s) 



CVS 

225 Makefile 

sharebroker 
usedcarsale 
225 bytes 



rj Directory of E:\e-speak-src_991217\platform\ES\tutorial\CVS 



;ii2/06/oo 


04:33p <DIR> 




^=^12/06/00 


04:33p <DIR> 




12/16/99 


06:22p 


48 


12/16/99 


06:23p 


42 


12/16/99 


06:22p 


36 


12/16/99 


06:22p 


46 


12/16/99 


06:22p 


846 




7 File(s) 


1, 01 



Entries 



Directory of E : \e-speak-src_991217\platf orin\ES\tutorial\sharebroker 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/06/00 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:33p 
04:33p 
04:26p 



<DIR> 
<DIR> 

<DIR> 
<DIR> 
<DIR> 



4 59 compile.bat 

conf ig 

CVS 

doc 

296 Makefile 



Page 111 



test 

12/07/99 04:26p 2,040 setenv 

12/07/99 04:26p 1,416 setenv.bat 

12/05/00 04:33p <DIR> src 

10 File(s) 4,211 bytes 

Directory of E: \e-spealc-src_991217\platform\ES\tutorial\sharebroker\c 
onf ig 



12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04: 33p 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 



8 File{s; 



CVS 

example 1 
exainple2 
example 3 
example 4 
examples 
0 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
=onfig\CVS 



il2/06/00 
^12/06/00 
■12/16/99 
^12/16/99 
12/16/99 
'12/16/99 
^12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
05:22p 
06:22p 
06:22p 
7 



<DIR> 
<DIR> 



File(s) 



3 Entries 
90 Entries. Log 
55 Repository 
46 Root 
846 Template 
1,040 bytes 



I Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
'onf igXexamplel 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/07/99 


04 


:26p 




20 


bank. pr 


12/07/99 


04 


:26p 




261 


bankvocab. ini 


12/07/99 


04 


:26p 




1,247 


BankVocabulary . xml 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




70 


runbankvocab . bat 


12/07/99 


04 


: 26p 




61 


runbankvocab. sh 


12/07/99 


04 


:26p 




110 


runvocabf inder . bat 


12/07/99 


04 


:26p 




100 


runvocabf inder . sh 






10 


File (s) 


1,86S 


> bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
onf ig\examplel\CVS 
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12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s) 



test 



366 Entries 
64 Repository 
46 Root 
84 6 Template 
1,322 bytes 



onf ig\example2 


12/06/00 


04 


: 33p 


12/06/00 


04 


:33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


ipl2/06/00 


04 


: 33p 


^012/07/99 


04 


:26p 


'=^42/07/99 


04 


:26p 


^^12/07/99 


04 


:26p 


^^12/07/99 


04 


: 26p 



<DIR> 
<DIR> 



<DIR> 



11 File(s) 



290 bank.ini 
18 bank.pr 
1,322 BankService.xml 
1,247 BankVocabulary.xml 
CVS 

65 runbankservice.bat 
90 runbankservice. sh 
107 runclient.bat 
98 runclient.sh 
3,237 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
onf ig\example2\CVS 



14.2/06/00 
=12/06/00 
%2/16/99 
r42/16/99 
42/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s) 



407 Entries 
64 Repository 
46 Root 

84 6 Template 
1,363 bytes 



onf ig\example3 




12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 


6 


12/07/99 


04:26p 


314 


12/07/99 


04:25p 


1, 097 


12/07/99 


04:26p 


18 


12/07/99 


04:26p 


1,322 


12/07/99 


04:26p 


1,247 


12/07/99 


04:26p 


1,091 


12/07/99 


04:26p 


131 



account . dat 
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test 

260 change_dir.gif 
254 connect.gif 
330 cpwd-gif 
320 create__vb.gif 
<DIR> CVS 

131 delete.gif 
182 disconnect.gif 
275 download.gif 
110 folder.gif 
174 help.gif 
423 localserver . ini 
300 login. gif 
1,189 open__act.gif 
213 reconnect.gif 
72 runserver.bat 
130 runserver.sh 
1,094 sell. gif 

918 ShareBrokerVocabulary.xml 
1,178 ShareBrokerService.xml 
95 starttrader . sh 
71 stocktrade.bat 
1,170 title.gif 

20 trader. pro 
1,335 Trader. xml 

20 traderlntf .pro 
1,253 TraderVocabulary.xml 
1,118 TraderService.xml 
314 upload.gif 
285 watch.gif 
le(s) 18,460 bytes 

Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
onf ig\example3\CVS 



12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


012/07/99 


04 


:26p 


^Ol2/07/99 


04 


:26p 


^^12/07/99 


04 


:26p 


W12/07/99 


04 


: 2 6p 


W12/O7/99 


04 


:26p 


1312/07/99 


04 


:26p 


^!^12/07/99 


04 


:26p 


^■^12/07/99 


04 


:26p 


1^ 12/07/99 


04 


:26p 


1:^12/07/99 


04 


: 26p 


^ifl2/07/99 


04 


:26p 


yi2/07/99 


04 


:26p 






39 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s) 



1,787 Entries 
64 Repository 
4 6 Root 
84 6 Template 
2,743 bytes 



Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
onf ig\example4 



12/06/00 04:33p 
12/06/00 04:33p 
12/07/99 04:26p 



<DIR> 
<DIR> 



6 account.dat 
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12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:25p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:25p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:2 6p 


12/06/00 


04 


: 33p 


312/06/00 


04 


: 33p 


012/07/99 


04 


:26p 


^^12/07/99 


04 


:26p 


«12/07/99 


04 


:26p 


^12/07/99 


04 


: 2 6p 


=^12/07/99 


04 


:26p 


!::i2/07/99 


04 


:26p 


^^12/07/99 


04 


:26p 


\^12/06/00 


04 


: 33p 


.r:i2/07/99 


04 


:26p 


n2/07/99 


04 


:26p 


212/07/99 


04 


:26p 


i?12/07/99 


04 


:26p 


^12/07/99 


04 


:26p 


=^12/07/99 


04 


:26p 



<DIR> 



<DIR> 
<DIR> 



<DIR> 



35 File(s) 



test 

314 addfunds . gif 
1,097 add_share.gif 
1,444 BankService.xml 
1,362 BankVocabulary.xml 
1,091 buy. gif 

131 cancelord.gif 

260 change_dir.gif 

254 connect.gif 

330 cpwd.gif 

320 create_vb.gif 
CVS 

delete. gif 
disconnect . gif 
download. gif 
folder . gif 
help. gif 
hostl 
host2 
login. gif 
open_act . gif 
reconnect . gif 
sell . gif 

ShareBrokerVocabulary . xml 
ShareBrokerService2 . xml 
ShareBrokerServicel . xml 
singlehost 
title.gif 
Trader. xml 

TraderVocabulary . xml 
TraderService . xml 
upload.gif 
watch. gif 
6 bytes 



131 
182 
275 
110 
174 



300 
1,189 

213 
1, 094 
1,485 
1,429 
1, 430 

1,170 
1,335 
1,253 
1,118 
314 
285 
20, 09 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
onf ig\example4 \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 

7 File(s) 



<DIR> 
<DIR> 



1,453 Entries 

50 Entries. Log 
64 Repository 
4 6 Root 
846 Template 
2,459 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
onf ig\example4\hostl 
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test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:26p 141 bank.pr 

12/07/99 04:26p 22 col 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 114 runbrokerl.bat 

12/07/99 04:26p 138 runbrokerl . sh 

12/07/99 04:26p 73 sharebrokerl.bat 

12/07/99 04:26p 672 sharebrokerl.ini 

12/07/99 04:26p 304 sharebrokerl . pr 

12/07/99 04:26p 158 sharebrokerl . sh 

12/07/99 04:26p 139 stocktrade . pr 

12 File(s) 1,761 bytes 

Directory of E: \e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
^ onf ig\example4 \host 1\CVS 

h2/06/00 04:33p <DIR> 
112/06/00 04:33p <DIR> 

^12/16/99 06:22p 448 Entries 

jl2/16/99 06:22p 70 Repository 

•^12/16/99 06:22p 46 Root 

;i2/16/99 06:22p 846 Template 

6 File(s) 1,410 bytes 

: Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
::onf ig\exainple4\host2 



;ifl2/06/00 


04:33p 


<DIR> 




^rl2/06/00 


04:33p 


<DIR> 




^=12/07/99 


04:26p 




141 


12/07/99 


04:26p 




22 


12/06/00 


04:33p 


<DIR> 




12/07/99 


04:26p 




115 


12/07/99 


04:26p 




137 


12/07/99 


04:26p 




73 


12/07/99 


04:26p 




730 


12/07/99 


04:26p 




302 


12/07/99 


04:26p 




177 


12/07/99 


04:26p 




139 



CVS 

runbroker2 ,bat 
runbroker2 . sh 
sharebroker2 . bat 



12 File(s) 1,836 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
onf ig\example4\host2\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
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12/16/99 06:22p 448 Entries 

12/16/99 06:22p 70 Repository 

12/16/99 06:22p 46 Root 

12/16/99 06:22p 846 Template 

6 File(s) 1,410 bytes 

Directory of E: \e-speak-src_991217\platform\ES\tutorial\sharebroker\( 
onf ig\example4\singlehost 



43 bank.pr 

CVS 

549 localserver.ini 
115 runbroker2.bat 
115 runbrokerl.bat 
72 runserver.bat 

206 sharebroker2 .pr 

207 sharebrokerl.pr 
71 stocktrade.bat 
43 stocktrade.pr 

1,421 bytes 

fl Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
i=;^onfig\example4\singlehost\CVS 

'^12/06/00 04:33p <DIR> 

yi2/06/00 04:33p <DIR> 

;i2/16/99 06:22p 456 Entries 

jfl2/16/99 06:22p 75 Repository 

^12/16/99 06:22p 46 Root 

=12/16/99 06:22p 846 Template 

6 File(s) 1,423 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 



12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




Q12/07/99 


04:26p 




^012/07/99 


04:26p 




'-I12/07/99 


04:26p 




W12/07/99 


04:26p 






12 


File (s) 



onf ig\example5 


12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 



<DIR> 
<DIR> 



6 account.dat 
314 addfunds.gif 
1,097 add_share.gif 

43 bank.pr 
1,444 BankService.xml 
1,362 BankVocabulary.xml 
1,091 buy.gif 

131 cancelord.gif 
2 60 change_dir.gif 
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1 o / ri'7 / no 
iz / U // 99 


o yi 

04 


: 26p 


IZ/ U / / 9 9 


o ^ 

04 


: 26p 


Iz/U //99 


O >1 

04 


: 26p 


IZ/ U // 99 


O /I 

04 


: 26p 


to I c\ r I r\r\ 


04 


: 33p 


LZ.I \J //99 


O >1 

04 


: 26p 


IZ/U //99 


O /] 

04 


O /" 

: 26p 


LZ/\j 1/99 


O /I 

04 


: 26p 


iz/U// 99 


04 


: 2 6p 


12/07/99 


04 


: 26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:25p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


:26p 


12/07/99 


04 


:25p 


12/07/99 


04 


:26p 


:^a2/07/99 


04 


:26p 


=yl2/07/99 


04 


:26p 


^^12/07/99 


04 


:26p 


:^:d2/07/99 


04 


:2 6p 


iXpl2/07/99 


04 


:26p 


=^^12/07/99 


04 


:26p 


;™42/07/99 


04 


:26p 




04 


2 6p 


;= 12/07/99 


04 : 


26p 


j7;12/ 07/99 


04 : 


26p 


=^fl2/07/99 


04 : 


2 6p 


==412/07/99 


04 : 


2 6p 


'^;42/07/99 


04 : 


2 6p 


=-12/07/99 


04 : 


2 6p 


--IL2/07/99 


04 : 


26p 


12/07/99 


04 : 


2 6p 


12/07/99 


04 : 


2 6p 


12/07/99 


04 : 


26p 


12/07/99 


04 : 


26p 


12/07/99 


04 : 


26p 


12/07/99 


04 : 


26p 


lO / AT / r\ ^ 

12/07/99 


04 : 


26p 


12/07/99 


04 : 


26p 


12/07/99 


04 : 


2 6p 


12/07/99 


04 : 


26p 


1 9 707 / QQ 


n /I • 


Z bp 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 



test 

18 cleandb.bat 
254 connect.gif 
330 cpwd.gif 
320 create_vb.gif 
<DIR> CVS 

131 delete.gif 
8, 4 05 deinoexample5.html 
182 disconnect . gif 
275 download.gif 
110 folder.gif 
174 help. gif 
5,687 Imagel.gif 
5,889 Imagel0.gif 
17,709 Imagell.gif 
13,800 Imagel2.gif 
13,68 6 Imagel3 . gif 

9,041 Image2,gif 
11,845 Image3.gif 
11, 859 Iinage4.gif 
10,472 Image5.gif 
12,712 Image6.gif 
9,852 image7.gif 
9,634 Image9.gif 
41,855 imageUUV.gif 
551 localserver . ini 
300 login.gif 
1,18 9 open_act.gif 
5,522 README_EXAMPLE5.txt 
213 reconnect.gif 
115 runbroker2 .bat 
115 runbrokerl -bat 
72 runserver.bat 
10, 163 sample. j serv. properties 
1,094 sell, gif 

7 2 sharebroker . bat 

206 sharebroker2 .pr 

20 shareBrokerlntf .pro 

1.429 ShareBrokerService2.xml 

207 sharebrokerl .pr 

1.430 ShareBrokerServicel .xml 
1,485 ShareBrokerVocabulary.xml 

71 3tocktrade.bat 
68 9 StockTrade.html 

43 stocktrade.pr 
1,170 title.gif 

43 trader. pro 
1,335 Trader. xml 

20 traderlntf .pro 

Page 118 



12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 

63 File(s) 



test 

1,253 TraderVocabulary.xml 
1,118 TraderService . xml 
314 upload.gif 
285 watch.gif 
220,512 bytes 



Directory of E: \e-speak-src_991217\platforra\ES\tutorial\sharebroker\c 
onf ig\example5\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s) 



2,999 Entries 
64 Repository 
46 Root 
846 Template 
3,955 bytes 



J Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\C 



J12/06/00 
J12/06/00 
312/16/99 
^12/16/99 
il2/16/99 
12/16/99 
'^12/16/99 



04:33p 
04:33p 
06:22p 
06:23p 
06:22p 
06:22p 
06:22p 

7 File(s} 



<DIR> 
<DIR> 



186 Entries 
42 Entries. Log 
48 Repository 
4 6 Root 
84 6 Template 
1,168 bytes 



B Directory of E:\e-speak-src_991217\platforra\ES\tutorial\sharebroker\d 



=-10 c 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 1,806,132 ShareBrokerDocs.zip 

4 File(s) 1,806,132 bytes 

Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\d 
oc\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s: 



59 Entries 
52 Repository 
46 Root 
846 Template 
1,003 bytes 
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test 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker \s 
rc 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


:33p 


<DIR> 


examplel 


12/06/00 


04 


: 33p 


<DIR> 


example 2 


12/06/00 


04 


: 33p 


<DIR> 


examples 


12/06/00 


04 


: 33p 


<DIR> 


example4 


12/06/00 


04 


: 33p 


<DIR> 


examples 






8 


File (s) 


0 bytes 



Directory of E: \e-speak-src_991217\platf orni\ES\tutorial\sharebroker\s 
rc\CVS 



□ 12/06/00 


04:33p 


<DIR> 






^012/06/00 


04 : 33p 


<DIR> 






'==112/16/99 


06:23p 




3 


Entries 


UI12/16/99 


06:23p 




90 


Entries . Log 


UI12/16/99 


06:23p 




52 


Repository 


012/16/99 


06:23p 




46 


Root 


1=^12/16/99 


06:23p 




846 


Template 



7 File(s) 1,037 bytes 



"^^l Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\s 
^jfrc\examplel 



B12/06/00 


04 


:33p 


<DIR> 




^2/06/00 


04 


: 33p 


<DIR> 




312/07/99 


04 


:26p 




4,723 BankVocabulary . java 


12/07/99 


04 


:26p 




4,109 BankVocabFinder. java 


12/07/99 


04 


:26p 




353 compile.bat 


12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/07/99 


04 


:26p 




361 Makefile 






7 File 


(s) 


9,546 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
rc\examplel\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File(s) 



209 Entries 
61 Repository 
4 6 Root 
84 6 Template 
1,162 bytes 
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test 



Directory of E: \e-speak~src_991217\platf orm\ES\tutorial\sharebroker\s 
rc\example2 



12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07 /99 


04 


: 27p 




>j f ^ ^ \j 


rT.wwkJ U.il C IN u.iliJ^./C i. ocilc J_ a U . J ci V ci. 


12/07 /99 


04 


: 27p 




1 930 




12/07 /99 


04 


: 27p 




6 326 


1^ di. 1 JVV, LXCliU • jClvCl 


12/07/99 


04 


: 27p 




2 748 


n k" ^ ^ y^T ir'f^Trrh'F P^cr-iHl 


12/07 /99 


04 


• 27d 




O f J- z? ^ 


R 3 n V Q o "mr n r^oTri'h'FTr'-! r\ a ~\ ziTr^a 
£jCLlliS.Ot;X vJLC't:XiiUi-£. -LXlLIfciJ- • JdVcl 


12/07 /99 


04 


: 27p 








12/07/99 


04 


:27p 




4, 094 


BankService . j ava 


12/07/99 


04 


:27p 




4,731 


BankVocabulary . j ava 


12/07/99 


04 


:27p 




1,823 


Company . esidl 


12/07/99 


04 


:27p 




491 


compile.bat 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


□12/07/99 


04 


:27p 




1, 007 


Makefile 


012/07/99 


04 


:27p 




2,063 


OrderDetailParam. esidl 


yl2/07/99 


04 


:27p 




2,275 


Semaphore . j ava 


iAll2/07/99 


04 


:27p 




2,003 


ShareDetailParam. esidl 


UI12/07/99 


04 


:27p 




3,223 


ShareDetail, java 


012/07/99 


04 


:27p 




2, 461 


UserAccount . j ava 



19 File(s] 



57,296 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebrok;er\s 
~rc\example2\CVS 



=12/06/00 
VL2/06/00 
=112/16/99 
3L2/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File (s) 



874 Entries 
61 Repository 
4 6 Root 
84 6 Template 
1,827 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
rc\example3 



12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:27p 




3,325 


AccountNumberGenerator . j ava 


12/07/99 


04 


:27p 




5,773 


AddFundsGUI .java 


12/07/99 


04 


:27p 




1,930 


Address . esidl 


12/07/99 


04 


:27p 




8,140 


AddSharesGUI . j ava 


12/07/99 


04 


:27p 




10,909 


AuthorizationWindow. java 


12/07/99 


04 


:27p 




2, 783 


BankServicelntf. esidl 


12/07/99 


04 


:27p 




3,119 


BankServicelntf Finder . java 
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1 9 707 / QQ 


U 4 


: 2 /p 


19/n7/QQ 


n A 


• O 7v^ 

: 2 /p 


IZ / U 1 / yy 


U4 


: 2 /p 


19/n7/QQ 


U4 


: 2 /p 


1 9 / m / QQ 

iz/ u / / y y 


A / 

04 


: 27p 


1 9 / n'7 / QQ 


A / 

04 


: 27p 


19/07 / QQ 

IZ / u / / y y 


U4 


: 2 /p 


1 9 / n7 / QQ 
XZ / U 1 / yy 


U4 


: 2 /p 


1 9 / Hi^/nn 
IZ/Ub/UU 


A A 

04 


: 33p 


1 9 / n7 / QQ 

iz / u / / y y 


A /i 

04 


:27p 


1 9 / ri'7 / QQ 

iz/u / /yy 


A /I 

04 


: 27p 


1 9 /n7 / QQ 

iz / u / / y y 


A A 
04 


: 27p 


10/1 c / r\ r\ 

12/15/99 


A j1 

04 


: OOp 


12/07/99 


A A 

04 


:27p 


lz/\j / /yy 


A >1 

04 


: 27p 


12/07/99 


04 


: 27p 


iZ/U //99 


A /t 

04 


: 27p 


i^j 12/07/99 


O /I 

04 


: 27p 


1 o / n 1 / Q Q 

;|j 12/ u / / y y 


A A 

04 


: 27p 


^-lO / AT / AO 

^•=.5 12/07/99 


04 


: 27p 


:^j12/u / /yy 


A >1 

04 , 


27p 


1^,^ 12/U //99 


A A 

04 : 


27p 


:,il2/07/99 


04 : 


27p 


i^^l2/07/99 


04 : 


27p 


1^^-12/07/99 


04 : 


27p 


- 12/07/99 


04 : 


27p 




04 : 


27p 


■^.'?12/0 / /99 


A A 

04 : 


27p 


=..".ia2/o / /yy 


O A 

04 : 


27p 


itH o / n 7 / Q Q 

=r^^iz/ u / / y y 


A ^ . 

04 : 


27p 


O / A ^ / A A 

= :ril2/0 7/99 


A A 

04 : 


27p 


iin ? / n7 / QQ 


u ^ • 




12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 



46 File(s) 



test 

14,971 BankServicelmpl. java 
4,083 BankService. java 
4,723 BankVocabulary . java 
18,119 BrokerLogic. java 
10,571 BuySharesGUI. java 
7,170 ChangePasswordGUI . java 
1,819 Company. esidl 
689 compile.bat 
<DIR> CVS 

9,308 ListAccountGUI. java 
18,944 ListSharesGUI. java 
7,871 LoginGUI. java 
2,405 Makefile 
1,901 MatchThread. java 
5,656 MessageDialog. java 
7,592 OpenAccount GUI. java 
2,063 OrderDetailParam. esidl 
3,610 OrderDetail. java 
9,686 SellSharesGUI. java 
2,279 Semaphore . j ava 
2,650 ServiceDeployer . java 
2,225 ShareBrokerlntf .esidl 
3,256 ShareBrokerlntf Finder. java 
4,600 ShareBrokerlmpl. java 
2,046 ShareDetailParam. esidl 
3,223 ShareDetail . java 
4,449 StartShareBrokerService. java 
6,322 StartTraderService. java 

23,802 StockTrade. java 
1,921 TraderQuerySpec. esidl 
4,840 TraderVocabulary. java 
1,948 Traderlntf .esidl 
2,731 TraderService. java 
4,384 Traderlntf Finder. java 
2,97 9 Traderlmpl. java 
1,959 Transaction. esidl 
2,459 UserAccount. java 

245,243 bytes 



rc\exampl^3\CVs'''^~^^^^^"^''''-^^^^^^^^^^ 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 



<DIR> 
<DIR> 



2,389 Entries 

61 Repository 

4 6 Root 

846 Template 
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6 File(s) 



test 
3,342 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
rc\example4 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


: 27p 




3, 407 


AccountNumberGenerator . i ava 


12/07 /99 


04 


: 27p 




5,829 


AddFundsGUI "lava 


12/07/99 


04 


:27p 




1, 930 


Addres s es idl 


12/07/99 


04 


: 27p 




8, 196 


AddSharpsGUI iava 


12/01 799 


04 


: 27p 




10 880 


LU. 1 1 \J J_ -L ^ C3. l_. J- W 1 i w V _L 1 vV ■ _J CI V d 




04 






9 781 


ijCiiijs.o\z;x vxv^tjxiiux > cdxlaX 


12/07 /99 


04 


• 27n 




6 0S2 


11^ ri V ^ A "T'^r 1 r'P T "H t" F*! "H H T" '^t^'^t^ 
ijciiijs.oox v-L^-^cxj.J.uxj- xii^cj- • J ay a. 


12/07/99 


04 


• 27d 




17 69^ 


R a n V- Q p y-TT 1 r'P Ttti'Pi 1 "1 j^^TT";^ 
XJCliijS.iJ>CX vx^c xitip X ■ J Q V d 


12/07 /99 


04 


• 27n 




4 199 


OCliiXvOC'X VX'i^C-. JClvCl 




04 


' 27n 




4 7 1 R 

*i , f J. O 


Odii is. V Dv— cii->U.XciL y • J a. v a 






• 97n 




11 1 n 1 


Dx C_) K-^X XiC/y i C • JdVcl 


f=n 9 707 /QQ 


04 


• 97n 




10 RIO 


J_>U.y01ictXfc^okjL/X • Jdvci 


-^1 9 707 / QQ 


04 






S 97 S 


\w^ciiiUt;xvJx Llferx kjU X . JdVd. 


hn 2/07/99 


04 


• 27n 




1 189 


a "n rrtf^ P a Q QWrN Tdr^Tl T "i ;:>^t;^ 
v^ii.ciiiyc;ir do owwx \x\d \j x * j d v d 


hli 2/07/99 


04 


• 97n 




1 R 1 9 


C r\Tt\TS ^ T\\7 Q "! H 1 


Q12/07/99 


04 






691 


r^onrni 1 h^f* 

\^ WlLl^ X X O > iw^d u 


i -^12/06/00 


04 


: 33p 


<DIR> 




TVS 


ilJl 2 / 07 /99 


04 


• 27d 




2 049 


H 1 T~ "1 irA 
iJ.^_Lk/^A. • i a. V CI 


1 9 707 799 


04 


• 97n 




9 101 


Xl -L O L-X^w Lllit-OL^X • JdVd 


^^12707/99 


04 


: 27p 




6 758 


X->-UOL.i-JCI.i.lJ\.OVJWX * _Jdvd 


=1il 9/07/99 


04 


• 27n 




1 SIR 


Xj X o u ox JVC- X o w U X • J ct V ci 


2/07/99 


04 


• 97n 




18 889 

X U , (J U 


T."i Q "h ^ Vi ;^ y Qf^TT T "ipirp 

XiXo(— OiiCtXC-OwUX • JClVd 


^'8l2/07/99 


04 


: 27p 




7, 920 


LoainGUI . i ava 


^3l2/15/99 


04 


: OOp 




2,835 


Ms Vp -F -i 1 p 

L xa Jvv^ j_ j_ _i_ 


^12/07/99 


04 


: 27p 




1 901 


M;^i~ pViTh T(=i;^d ~i;=t'^7;^ 

LidC^w^ilXilX^ClV-l* JClvCl 


12/07/99 


04 


: 27p 




5, 657 


1 1 ^ O O CL M ^ ~L. d. ^ W ^ > I d. V d 


12/07 /99 


04 


: 27p 




3,255 


Mpc;q = rrppl i pnt" '\r^vf\ 

L i ^ O O d ^ V..^ -I — L liU>> JClVd 


12/07/99 


04 


:27p 




7^ 618 


OpenAccountGUI . j ava 


12/07/99 


04 


:27p 




2,065 


OrderDetailParam. esidl 


12/07/99 


04 


:27p 




3, 178 


OrderDetail . j ava 


12/07/99 


04 


:27p 




2, 054 


ReqAuthThread . j ava 


12/07/99 


04 


:27p 




7,236 


SelectBankGUI . java 


12/07/99 


04 


:27p 




9,890 


SellSharesGUI .java 


12/07/99 


04 


:27p 




2,277 


Semaphore. java 


12/07/99 


04 


:27p 




3,005 


ServiceDeployer . j ava 


12/07/99 


04 


:27p 




2,537 


ShareBrokerlntf . esidl 


12/07/99 


04 


:27p 




6,943 


ShareBrokerlntf Finder . java 


12/07/99 


04 


:27p 




6,917 


ShareBroker Impl . j ava 


12/07/99 


04 


:27p 




2,259 


ShareBrokerEvent Distributor 


a 

12/07/99 


04 


:27p 




2,048 


ShareDetailParam. esidl 
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test 



12/07/99 


04 


:27p 


3, 226 


ShareDetail . j ava 


12/07/99 


04 


:27p 


6, 678 


S t art ShareBroker Service . j ava 


12/07/99 


04 


:27p 


6, 346 


StartTraderService . java 


12/07/99 


04 


:27p 

IT 


5,204 


StatusWindow . java 


12/07/99 


04 


:27p 


26, 825 


StockTrade . j ava 


12/07/99 


04 


:27p 


1, 946 


TraderQuerySpec . esidl 


12/07/99 


04 


:27p 


3, 929 


Traderlntf Finder . j ava 


12/07/99 


04 


:27p 


2,080 


Traderlntf. esidl 


12/07/99 


04 


:27p 


3,774 


Traderlmpl .java 


12/07/99 


04 


:27p 


5, 030 


TraderVocabulary . java 


12/07/99 


04 


:27p 


2, 730 


TraderService . java 


12/07/99 


04 


:27p 


1,969 


Transaction. esidl 


12/07/99 


04 


:27p 


2,461 


UserAccount . j ava 



55 File(s) 321,699 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
rc\example4 \CVS 

J12/06/00 04:33p <DIR> 

412/06/00 04:33p <DIR> 

J12/16/99 06:23p 2,891 Entries 

J12/16/99 06:23p 61 Repository 

312/16/99 06:23p 46 Root 

;^;a2/16/99 06:23p 846 Template 

y 6 File(s) 3,844 bytes 

Directory of E:\e-speak-src_991217\platforin\ES\tutorial\sharebroker\ 
|;4:c\example5 



^2/06/00 


04 


: 33p 


<DIR> 




a.2/06/00 


04 


:33p 


<DIR> 




»l2/07/99 


04 


:27p 


3, 408 


AccountNumberGenerator . j ava 


12/07/99 


04 


:27p 


5, 120 


AddFundsGUI . j ava 


12/07/99 


04 


:27p 


2, 62 9 


AddFundServlet . j ava 


12/07/99 


04 


:27p 


1, 932 


Address . esidl 


12/07/99 


04 


:27p 


3,248 


AddSharesServlet . java 


12/07/99 


04 


:27p 


7,505 


AddSharesGUI . j ava 


12/07/99 


04 


:27p 


11, 907 


AuthorizationWindow. java 


12/07/99 


04 


:27p 


3,870 


AuthoriseOrderServlet .java 


12/07/99 


04 


:27p 


2,783 


BankServicelntf . esidl 


12/07/99 


04 


:27p 


9,119 


BankServicelntf Finder . java 


12/07/99 


04 


:27p 


17,380 


BankServicelmpl . j ava 


12/07/99 


04 


:27p 


4,436 


BankService . j ava 


12/07/99 


04 


:27p 


4, 907 


BankVocabulary , java 


12/07/99 


04 


:27p 


33,346 


BrokerLogic. java 


12/07/99 


04 


:27p 


3,346 


BuySharesServlet . java 


12/07/99 


04 


:27p 


9,070 


BuySharesGUI .java 


12/07/99 


04 


:27p 


2,443 


CancelOrderServlet . j ava 
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test 

2^0 9 IVVi^ ''''' ChangePasswordServlet.java 

11 01^ ^'^'^ ChangePasswordGUI.java 

ll/ll/ll n. ^'^^^ CheckSharesThread.java 

12/07/9? 04 ?7^ CheckSharesServlet.java 
J2/07/99 04:27p 1,823 Company . esidl 

\V,IVjII n'^^'P compile.bat 

2/o2 on o.'l? ''°20 ConnectionClass.java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:27p 2,536 Encoder. java 

^?/n7/9? IVVn^ 1'^^° GetShareBrokerListServlet.java 

,12/07/99 04:27p 2, 049 Helper. java 

12/07/qq IVV,^ 2,621 ListAccountSharesServlet.java 

^2/^7/99 n!1? 8, 679 ListAccountGUI. java 

12/07/9? ^7^ ^'^'^ ListAccountBalanceServlet.java 

19/07/00 n. "^'^"^l ListBanksGUI.java 

-I2/S7/9? 0417'' "'"'^ ListBanksServiet.java 

"^2/07/9? 0^ 9? 2'^'^ ListBrokersServlet.java 

"12/S7/99 0^97^ ListBrokersGUI.java' 

"12/S7/?? 04^7^ ^'2°1 Lis tSharesServlet. java 

^12/07/?? 0^97^ Lis tSharesGUI. java 

^12/S7/?? ?7^ ^'^^5 ListShareBrokersGUI.java 

'". n/?^ 04:27p 7,521 LoginGUI . java 

? /?q °4=nn^ 2,501 LoginServiet . java 

%o/i5^oo 3,091 Makefile 

^nW07/oo n^o^^ 1,901 MatchThread. java 

:;12/07/99 04:27p 2,122 MessageDump . java 

^2/07/?9 IVVi'' 5, 678 MessageDialog. java 

%2/S?/9? 04^7^ MessageClient.java 

04:27p 5, 908 Message, java 

^2 S4I? ^'''^ OpenA^ountServlet.java 

l2/S7/?9 0^7? 8, 990 OpenAccountGUI. java 

ll/ll/ll IVVl^ OrderCollect ion. java 

12/07/?? 04I7'' OrderDetailParam. esidl 

12/07/99 04:27p 3,182 OrderDetail . java 

i^?/n.'/oo 1^891 QuerySpec. esidl 

2 0? 417^ QuerySpec.java 

12/07/?? 0^1? 2'°^^ ReqAuthThread.java 

12/07/99 04:27p 7,129 SelectBankGUI . j ava 

2/ 0417^ SellSharesServLt.java 

19/^7/00 n^^? 8'^°2 SellSharesGUI.java 

.mV^ll 2,275 Semaphore, java 

WO /?? n.'l.'P 2,598 ServiceDepLyer.java 

I2/S7/?? 04^7"^ ShareBrokerlitf. esidl 

^2/07/?? 0^ 9? ^'^2^ ShareBrokerlntf Finder, java 

i9/07/?o n^o^P ^'299 ShareBrokerlmpl.java 

12/07/99 04:27p 2,261 ShareBrokerEventDistributor . jav 
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test 




12/07/99 


04 


:27p 


2, 045 


ShareDetailParam esidl 


12/07/99 


04 


:27p 


3, 565 


ShareDet ai 1 iava 


12/07/99 


04 


:27p 


6, 741 


Start ShareBroker Service . j ava 


12/07 /99 


04 


: 27p 


5, 365 


St rirtTradprS^rvippSprvl pt i;5v;5 


12/07 799 


04 


:27p 


3, 254 


Start TTf^ciprSpTvipp iava 


12/07/99 


04 


: 27p 


4 , 708 


S t at usWindow iava 


12/07/99 


04 


:27p 


29, 153 


StopkTradp iavr5 

(w* C< \J W i\. X X Ci \Ji ">C- • 1 Ci V Ci 




04 


: 27p 


1, 945 


Tra dp rOne rvSner* p<=5idl 

X X Ci C— X Ci X V iw* fw' • _i_ _J_ 


12/07/99 


04 


: 27p 


5, 059 


T "T^ dp tVop;r bill 1 a TV nava 

X X <ZX Vwivl- X V \^ v-- Ci ■kw' Iwi _L. Ci X y • J Ci V CL 


12/07 /99 


04 


• 27n 


7 078 


j.j_ctncxXiiuj_ • coxm. 


12/07/99 


04 


:27p 


2,729 


TraderService . j ava 


12/07/99 


04 


:27p 


3,944 


Traderlntf Finder . j ava 


12/07/99 


04 


:27p 


3, 614 


Trader Impl . j ava 


12/07/99 


04 


:27p 


1,986 


Transaction . j ava 


12/07/99 


04 


:27p 


2,545 


UserAccount . j ava 






81 File(s) 


403, 670 bytes 



I Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebro]cer\s 
lrc\example5\CVS 



112/06/00 
112/06/00 
112/16/99 
■^12/16/99 
112/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File (s! 



4,413 Entries 

61 Repository 
46 Root 
846 Template 
5,366 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\usedcarsale 



=^12/06/00 
^2/06/00 
12/07/99 
12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/06/00 



04:33p 
04:33p 
04:27p 
04:33p 
04:33p 
04:33p 
04:27p 
04:27p 
04:27p 
04:27p 
04 :27p 
04:27p 
04:33p 
04:27p 
04:27p 
04:27p 
04:33p 

17 File{s) 



<DIR> 
<DIR> 

<DIR> 
<DIR> 
<DIR> 



<DIR> 



<DIR> 



1,208 Carsales.ini 
conf ig 
CVS 
html 
229 Makefile 
5,938 README 

12 6 runcore.bat 
472 runservers.bat 
5,923 sample. zone. properties 
10,177 sample. jserv. properties 
servlets 
2,892 setenv 
2,152 setenv.bat 
6 Slides. ppt 
src 

29,123 bytes 
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test 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\usedcarsale\c 



onf ig 






12/06/00 


04 


• 33d 


12/06/00 


04 


: 33p 


19/07 /QQ 




• 97n 




04 


• 97n 




OA 


• 9 7o 
. ^ /p 


19 / n7 / QQ 


U H. 




19/n7/QQ 


U 4 


• 97o 


1 ? /07 /99 


04 


' 27d 


12/07/99 


04 


:27p 


12/06/00 


04 


:33p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


:-ll2/07/99 


04 


:27p 


ifll2/07/99 


04 


:27p 


^2/07/99 


04 


:27p 



<DIR> 
<DIR> 



<DIR> 



16 File(s) 



117 Buyerl.pr 

97 Buyer2.pr 

73 CarAd.pr 

105 CarBrok;er2.pr 

132 CarBrokerl.pr 

22 co.MYCOl 

22 co.MYCO 
CVS 

1,129 input, ptml 

129 Payment. pr 

737 response. ptml 

99 Sellerl.pr 

97 Seller2.pr 

141 SendMailServer .pr 
2,900 bytes 



5 Directory of E:\e-speak-src_991217\platform\ES\tutorial\usedcarsale\c 
=k5nf ig\CVS 



li 12/06/00 
W2/06/00 
1112/16/99 
a2/16/99 
iBL2/16/99 
a2/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File (s) 



621 Entries 
55 Repository 
4 6 Root 

846 Template 
1,568 bytes 



Directory of E: \e-speak-src 991217\platf orm\ES\tutorial\usedcarsale\C 



vs 






12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:23p 


495 Entries 


12/16/99 


06:23p 


61 Entries. Log 


12/16/99 


06:23p 


48 Repository 


12/16/99 


06:23p 


4 6 Root 


12/16/99 


06:23p 


84 6 Template 




7 File(s) 


1,496 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\usedcarsale\h 
tml 
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12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:27p 

12/07/99 04:27p 

]12/07/99 04:27p 

112/07/99 04:27p 

J12/07/99 04:27p 

J12/07/99 04:27p 

J12/07/99 04:27p 

312/07/99 04:27p 

^'12/07/99 04:27p 

J12/07/99 04:27p 

12/07/99 04:27p 

26 File(s) 



test 



5,634 AdvertiseToSell.html 

1.828 BuyerFirstScreen.html 
2,456 BuyerLogin2.html 
2,456 BuyerLoginl.html 
1,757 buyerops.html 

2,660 BuyerRegister2.html 

2.660 BuyerRegisterl.html 
1,878 CarbrokerFirstScreen2.html 
1,876 CarbrokerFirstScreenl.html 
3, 469 choice2.htinl 

3,469 choicel.html 
CVS 

images 
14,010 newcarsales.html 
1,824 SellerDetails.html 
1,888 SearchForSellers.html 
2,456 SellerLoginl.html 

1.829 SellerFirstScreen.html 

2.661 SellerRegister2.htinl 
2,661 SellerRegisterl.html 
1,661 sellerops .html 
2,458 SellerLogin2.html 
1,343 thanks . html 

20,513 webdemo.html 
83,447 bytes 



itmi\?5s°''^ ^^\^-^P^^'^-src_991217\platfom\ES\tutorial\usedcarsale\h 



a.2/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
06:23p 

7 File(s] 



<DIR> 
<DIR> 



1,205 Entries 

16 Entries. Log 
53 Repository 
46 Root 
846 Template 
2,166 bytes 



Directory of E: \e-speak-src_991217\platform\ES\tutorial\usedcarsale\h 
cmix images 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:27p 
04:27p 
04:27p 



<DIR> 
<DIR> 



13,761 buy.jpg 
11,004 car3_anm.gif 
19,273 carbroker.jpg 
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12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
a2/07/99 
:12/07/99 



04:33p 

04:27p 

04:27p 

04:27p 

04 :27p 

04:27p 

04:27p 

04 :27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

24 File(s) 



<DIR> 



test 

52 
2, 578 
82,264 
971 
971 
98,743 
160,012 
161,302 
110,035 
123,161 
128, 175 
131,157 
141,087 
157,932 
161,582 
159,451 
7,986 
398 
1,671,895 



CVS 

espeak. JPG 
happy. gif 
interact . jpg 
left-hand. gif 
right-hand. gif 
si. jpg 
slO. jpg 
sll . jpg 
s2.jpg 
s3 . jpg 
s4.jpg 
s5 . jpg 
s6. jpg 
s7.jpg 
s8 . jpg 
s9.jpg 
seller . jpg 
visal_60x38_a . gif 
' bytes 



J12/06/00 
12/06/00 
n2/16/99 
J12/16/99 
312/16/99 
312/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File (s: 



965 Entries 
60 Repository 
46 Root 
846 Template 
1,917 bytes 



^r-i^.lff''^ ^ = \^-^P^^k-src_991217\platform\ES\tutorial\usedcarsale\£ 



ervlets 

12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/15/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:27p 
04:33p 
04:00p 
04:27p 
04:27p 
04:27p 
04:27p 
9 



<DIR> 
<DIR> 

<DIR> 



File (s; 



880 compile.bat 
CVS 

663 Makefile 
4,158 Register . java 
38,178 RunCarSellerClient . java 
46,235 RunCarBuyerClient . java 
13,415 RunCarBrokerService . j ava 
103,529 bytes 



eri^ets\CVS°^ \^-^P^^k-src_991217\platform\ES\tutorial\usedcarsale\. 
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test 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:23p 326 Entries 

12/16/99 06:23p 57 Repository 

12/16/99 06:23p 46 Root 

12/16/99 06:23p 846 Template 

6 File(3) 1,275 bytes 



Directory of E: \e-speak-src_991217\platform\ES\tutorial\usedcarsale\s 
rc 



1//U6/00 


A A 

04 


: 33p 


<DIR> 






• 


12/05/00 


A A 

04 


: 33p 


<DIR> 






• • 


12/07/99 


A A 

04 


:27p 




11, 


086 


BrokerManager . j ava 


"1 O / AT / AA 

12/07/99 


A A 

04 


: 27p 




2, 


088 


Buyerinf o. esidl 


12/0 / / y 9 


A A 


: 2 /p 




1 A 

19; 


A IT C 

355 


BuyerManager, java 


1A /AT / AO 

-I 12/07/99 


A A 

04 


: 27p 






416 


CarAdlntf . esidl 


p 12 / U / / 99 


A yi 

04 


; 2 /p 




1 A 

13, 


041 


CarAdlmpl . j ava 


r.j' 1 / / u / / y 9 


A A 

U4 


: 2 /p 




A 

2 , 


AAA 

902 


CarBrokerlntf . esidl 


. "TO/A'7/AA 

!y 12/u / /yy 


A /I 

04 


• A 1 

: z ip 




15, 


1 A A 

108 


CarBroker Impl . j ava 


ijj 12/0 / /yy 


A / 

04 


: 2 /p 




2 , 


416 


CarDetails . esidl 


.IJI 1 9 / A 7 / Q Q 


U 4 


• z /p 






c: £^ 
D D o 


coinpile . bat 


U 12/07/99 


04 


:27p 




2, 


929 


Constants . j ava 


ii|12/06/00 


04 


: 33p 


<DIR> 






CVS 


;;"l2/07/99 


04 


:27p 




2, 


137 


Deal Details . esidl 


y=12/15/99 


04 


: OOp 




2, 


078 


Makefile 


iill2/07/99 


04 


:27p 




2, 


094 


Paymentlntf .esidl 


012/07/99 


04 


:27p 




6. 


501 


PaymentServer , j ava 


ini2/07/99 


04 


:27p 




3, 


322 


Payment Iiupl . j ava 


012/07/99 


04 


:27p 




2, 


071 


PTML. esidl 


i:;il2/07/99 


04 


:27p 




2, 


152 


Sellerlntf . esidl 


12/07/99 


04 


:27p 




21, 


491 


SellerManager . j ava 


12/07/99 


04 


:27p 




2, 


190 


Seller Info. esidl 


12/07/99 


04 


:27p 




8, 


164 


Sellerlmpl . java 


12/07/99 


04 


:27p 




2, 


259 


SendMaillntf. esidl 


12/07/99 


04 


:27p 




4, 


043 


SendMailServer . j ava 


12/07/99 


04 


:27p 




3, 


714 


SendMaillmpl . j ava 


12/07/99 


04 


:27p 




6, 


565 


ServiceStopper . j ava 


12/07/99 


04 


:27p 




2, 


367 


Stoppable. java 


12/07/99 


04 


:27p 




3, 


580 


Util . java 



29 File(s) 147,625 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\usedcarsale\s 
rc\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
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12/16/99 06:23p 
12/16/99 06:23p 
12/16/99 06:23p 
12/16/99 06:23p 
6 

Total Files 
4189 



File (s) 
Listed: 

File(s) 18 



test 

1,369 Entries 
52 Repository 
46 Root 
84 6 Template 
2,313 bytes 



116,673 bytes 

0 bytes free 
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